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Эта статья завершает цикл, 
посвященный архитектуре 
шестнадцатиразрядных процессоров 
фирмы Іпіеі В своем развитии они 
прошли все этапы — от робкого 
появления на международном рынке, до 
полного расцвета и обидно быстрого 
ухода со сцены. Им на смену пришли 
могучие 32-битные кристаллы, уже 
сегодня занявшие практически все 
“ экологические ниши “ в компьютерной 
индустрии. В следующих номерах 
“ КомпьютерПресс “ мы постараемся как 
можно интереснее рассказать об их 
интимной, скрытой от постороннего 
взгляда жизни. 


Архитектура 

микропроцессоров 


Совершенно секретно, перед прочтением 
сжечь! 

Л. и Б. Стругацкие 

Аналогии, аналогии... 

Наверное, я не ошибусь, если скажу, что каждый из 
нас хотя бы раз в жизни слышал из уст “ответствен- 
ных" работников фразу: “Это вам знать не полага- 
ется!" — и немудрено, ведь тайны окружают человека 
на протяжении всей жизни. Посудите сами — сначала 
родители, блюдя нравственность своего чада, плетут 
ему байки про аиста и капусту, затем, уже в школе, 
на него заводится совершенно секретное личное дело, 
а потом он попадает во взрослый мир, где таинствен- 
ные и легендарные тени КГБ, МВД и ВПК грозно ре- 
ют над несчастным любознательным индивидуумом до 
конца его дней. Но вот парадокс: соблюдение своих 
секретов и разгадывание чужих — эта чрезвычайно 
сложная и очень дорогая игра для серьезных дяде- 
нек — приносит, в основном, сугубо отрицательный 
результат. Мало того, что на обмундирование и про- 
корм всей этой оравы уходит масса средств, так ока- 
зывается и тайны-то отечественные остаются таковы- 


ми только для местных жителей, а разгадка чужих 
требует не нашей технологии и не наших знаний. 

Другое дело тайны компьютерные. Многолетний 
опыт показывает, что на создание секретных зон в 
ОЗУ потратиться стоит. У некоторых читателей 
подобный тезис может вызвать удивление, но если 
вдуматься, действительно начинаешь сомневаться, весь 
ли объем оперативной памяти машины должен быть 
доступен для любого пользователя? Давайте попробуем 
в этом деле разобраться. 

Берегите ОС 

Грубо говоря, программное обеспечение, располо- 
женное в ОЗУ, можно разделить на две основные 
части: операционную систему (ОС) и прикладные 
программы. Первая, как вам известно, служит для уп- 
равления аппаратными ресурсами компьютера и 
осуществления взаимодействия между прикладными 
программами, пользователем и “железом". Она явля- 
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ется как бы диспетчером для всех процессов, происхо- 
дящих в вычислительной системе. Если провести па- 
раллель между компьютером и человеческим организ- 
мом, то ОС в большинстве случаев выполняет функ- 
ции вегетативной, а прикладные программы — цен- 
тральной нервной системы. 

Теперь представьте себе на минутку, что написан- 
ная вами программа случайно внесла какие-то измене- 
ния в один из сегментов ОС. Это почти наверняка 
приведет к нарушению таких жизненно важных для 
компьютера функций, как управление памятью, вво- 
дом-вывоДом или файловой системой. Продолжая ана- 
логию с человеком, практически невозможно предста- 
вить себе ситуацию, когда чтение утренней газеты вы- 


зывает расстройство желудка, а разговор по телефону 
с приятельницей — появление склеротических сим- 
птомов. 

Для того чтобы избавить вычислительную систему 
от неминуемой катастрофы, разработчиками про- 
цессора І286 были предприняты некоторые меры по 
обеспечению безопасности модулей ОС. Рассуждали 
они, очевидно, так: если разделить все программное 
обеспечение на несколько уровней секретности, при- 
чем так, чтобы выполнение процедур с низким уров- 
нем не могло повлиять на состояние программ с более 
высоким уровнем, то, поставив операционную систему 
на самую вершину подобной пирамиды, можно уже не 
бояться неприятностей. 


Рис. 1. Классификация секретности документов Рис. 2. Уровни привилегий І286 



Рис. 3. Байт доступа Рис. 5. 



Рис. 6. Формат шлюза вызова 
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Равняйсь на Бюрократию 
или “Тайна второго кольца" 

Западные изобретатели — народ практичный и 
изобретать велосипед не в их привычках — куда де- 
шевле воспользоваться чужим опытом. Так вот, подоб- 
ную схему приоритетов они взяли не с потолка, а “не- 
редрали 44 прямо с системы защиты документов, кото- 
рой по сию пору пользуется правительство США. Там 
определено четыре класса секретности для бумаг, про- 
ходящих через * руки государственных чиновников: 
совершенно секретный, секретный, конфиденциаль- 
ный и неклассифицируемый (рис.1). Но это еще “цве- 
точки 44 — все население Штатов тоже разбито на че- 
тыре класса, которые называются “уровнями благона- 
дежности“: совершенно секретный, секретный, конфи- 
денциальный и неблагонадежный. При такой поста- 
новке дела совершенно ясно, что забулдыга из Куинз 
вряд ли получит доступ к стратегическим планам Пен- 
тагона. (Вот интересно, сколько уровней благонадеж- 
ности предусмотрел для советских граждан КГБ и в 
какую группу он включил сотрудников “Компью- 
терПресс“?) 

Схема защиты наиболее важных сегментов опера- 
ционной системы как две капли воды похожа на бю- 
рократическую “луковицу 44 , придуманную амери- 
канским правительством — те же четыре уровня, 
только называются они уровнями привилегий, а самый 
центр с нулевым номером уготован для сверхзащищен- 
ного “ядра безопасности 44 . Ядро предназначено для не- 
большой части ОС, отвечающей за управление памя- 
тью и доступом, а также за осуществление собственно 
защиты. Остальные сегменты операционной системы 
имеют первый уровень привилегий, на долю же при- 
кладных задач выпадает только третий уровень. Мо- 
жет возникнуть резонный вопрос: чем заполнить вто- 
рое кольцо безопасности и нужно ли оно вообще? 
Между прочим, четыре уровня получились, как вы, 
наверное, догадались не столько из-за слепого подра- 
жания, сколько потому, что число 4 кодируется двумя 
битами. Но “лишний 44 уровень не долго пустовал — 
нашлось и для него применение: существуют некото- 
рые программные продукты, например базы данных, 
которые сами занимаются своей безопасностью, вот 
им-то второе кольцо и пришлось как раз впору (рис. 
2 ). 

Остается пока неясным, каким образом процессор 
распознает уровень привилегии того или иного сегмен- 
та. Здесь нам придется ненадолго вернуться к той гла- 
ве, где мы знакомились с вычислением виртуального 
адреса и вспомнить, что назначение сорока битов из 
64-х разрядов дескриптора так и осталось для нас за- 
гадкой. Оказывается, разряды с 40-го по 47-й любого 
дескриптора занимает так называемый байт доступа, 
пятый и шестой биты которого несут информацию о 
номере кольца защиты (рис. 3). Комбинация этих 
двух разрядов как раз и является уровнем привилегий 
дескриптора ШРЬ). Если производится запись сегмен- 
та в ОЗУ, БРЬ играет роль определителя класса сек- 


ретности данных, а в том случае, когда сегмент содер- 
жит выполняемый код, уровень привилегий превраща- 
ется в показатель благонадежности программы. 

Откуда же берется содержимое БРЬ? Давайте 
вспомним структуру селектора (рис. 4). Из шестнад- 
цати его разрядов старшие тринадцать, как вы помни- 
те, отводятся под индекс, один служит индикатором 
таблицы, а вот два младших бита представляют собой 
запрашиваемый уровень привилегий (КРЬ). В про- 
цессоре предусмотрен специальный механизм под- 
держки текущего уровня привилегий (СРЬ), который 
соответствует степени “благонадежности 44 ДОРЬ) вы- 
полняемой процедуры. 

Для плебеев — отдельный вход 

Дальше, вроде бы, все просто: если СРЬ текущей 
программы меньше или равен БРЬ сегмента памяти, 
то доступ разрешен (вспомним, что нулевой уро- 
вень — самый высокий), а если налицо противопо- 
ложная ситуация, то есть СРЬ>БРЦ доступ запре- 
щен, не так ли? Вы не заметили в этом утверждении 
ничего странного? Тогда каким же образом приклад- 
ной программе достучаться до операционной системы 
и добиться от нее необходимой поддержки, ведь ее 
СРЬ по крайней мере на двойку больше, чем БРЬ сег- 
ментов ОС? 

Для того чтобы избежать подобного противоречия, в 
процессоре реализован механизм вызова более приви- 
легированной процедуры через разрешенные точки 
входа. Упрощенно это выглядит так: пользовательская 
программа обращается к специальному дескриптору, 
определяющему точку входа в процедуру операцион- 
ной системы (рис. 5). Специальный дескриптор носит 
название “шлюза вызова 44 , уровень его привилегий 
достаточно низок для того, чтобы к нему можно было 
обратиться из любой прикладной программы, а адрес 
заранее определен. Шлюз, помимо байта доступа, 
содержит счетчик слов, определяющий количество па- 
раметров, передаваемых при вызове, а также селектор 
и смещение назначения, точно указывающих вирту- 
альный адрес точки входа (рис. 6). 

Подобная косвенная передача управления через 
шлюз вызова имеет свои прелести: можно внести в 
пользовательскую программу какие угодно изменения 
или перекомпилировать ее, можно даже установить 
новую версию операционной системы, если для шлю- 
зов места в СЭТ (глобальной дескрипторной таблице) 
остались постоянными, достаточно изменить виртуаль- 
ный адрес точек входа и можно смело запускать при- 
кладную программу — она не “заблудится 44 . 

А теперь — совершенно секретная информация для 
самых любопытных. Советую читать при плотно за- 
крытых дверях и в полной темноте! В следующем вы- 
пуске нашего журнала мы расскажем о том, что дела- 
ется внутри І860, но это — военная тайна. Тс-с-с...!Н 

И. Липкин 
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ПЕРЕДАЧА ТЕКСТОВЫХ И ГРАФИЧЕСКИХ СООБЩЕНИИ 


Е 


ЬЕСТКОИІС 


Электронная - эффективно и надежно - ПОЧТЗ 

это то, что надо 
ЕСЛИ ЖЕ ОНА МОЖЕТ 

* передать сообщение многим абонентам 

* разместить сообщение на доске объявлений 

* поддержать непосредственный диалог 

* переадресовать сообщение 
ѵ ине только это, то - лтл 

Ли- то, что Взіуі требуется 

заключайте договор с ВНИИПАС и ВЫ окажетесь в великолепной 
компании абонентов электронной почты *ЕХРКЕ$$* 
институты АН СССР и отраслевые НИИ 
информационные агентства "Новости" и "Постфактум" 
Межрегиональный научно-технический комплекс "Микрохирургия глаза" 
\Ѵа 5 Ьіп§Іоп Ехрігішепіаі Іпіегпаііопаі Ра*а Сепіег, ІІ8А 
Советско-американский фонд "Культурная инициатива" 

ІІпіѵегека сіі Мііапо, Ііаіу 
СЕКИ, Сепеѵа 
издательство "Мир" 

МісЪі§ап Ііпіѵегзііу, ЫЗА 
и многие, многие другие 
организации и частные лица 
Советского Союза 
Европы 

Северной Америки 
П, Азии и Африки 

иЫ можете стать не только абонентом, 
но и владельцем электронной почты *ЕХРКЕ$$*, 
заключив с ВНИИПАС договор на поставку. 


БЫСТРЕЕ 

обычной и 
экспресс- 
почты 
телекса и 
телефакса 

ДЕШЕВЛЕ 


заключив с 


договор на поставку. 


МЫ ЖДЕМ ВАС 


Адрес 


СССР, 103009, Москва, Телефон 229-78-46, 229-11-18 

ул. Неждановой 2а, ВНИИПАС. Телекс 411809 ІРА5 8Л 

Телефакс (7-095) 229-32-37 


(С) СорупвЫ ІА5 — вгоир 
ІгаМи(е Тог АиТотаТе<Т Зужіеггв 


ИАС— групп разрабатывает различные программные системы для персона л ьны* компьютеров 
Справки по телефону 132-70-18 
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В процессе поиска новых мощных 
средств хранения информации 
исследователи пришли к выводу, что и 
старые не так уж плохи, если 
посмотреть на них с незнакомых ранее 
позиций. В результате проведенных 
изысканий появилось самостоятельное 
направление разработок дисковых 
магнитных накопителей — дисковые 
массивы, которые обещают стать 
новым поколением носителей 
информации и вытеснить в дальнейшем 
своих прародителей. 


ДИСКОВЫЕ МАССИВЫ 


Технический прием объединения магнитных дисков 
в дисковые массивы (бізк аггауз) становится основным 
в технологии создания современных мощных накопи- 
телей информации. За последние несколько лет разра- 
ботчики аппаратных средств испробовали множество 
способов повышения скорости обмена информацией, 
записанной на магнитных носителях. При помощи 
дисковых массивов удалось добиться повышения на- 
дежности и увеличения скорости передачи информа- 
ции, а также улучшить характеристики ввода-вывода. 
Но при всех достоинствах дисковых массивов имеются 
значительные трудности в разработке контроллеров, 
программного обеспечения и систем обработки оши- 
бок. 

Дисковые массивы воплощают простую идею о том, 
что несколько дисков, объединенных вместе, могут пе- 
редавать информацию быстрее, чем один диск. 

Самая популярная конфигурация, с четырьмя дис- 
ками данных и одним диском контроля четности, пе- 
ремещает данные почти в четыре раза быстрее, чем 
одиночный диск. Например, система, использующая 
четыре 5С5І (Зшаіі Сотриіег Зузіет Іпіегіасе) диска 
со скоростью передачи данных 3 Мбайт/сек каждый, 
может перемещать данные со скоростью 
10 Мбайт/сек. В сравнении с этим, недавно появив- 
шиеся одиночные диски 8СЗІ-2 обеспечивают скорость 
обмена 10 Мбайт/сек только при помощи весьма на- 
пряженного использования кэш-памяти. Более того. 


если разработчики дисковых массивов начнут исполь- 
зовать ЗС5І-2 диски, четырёхдисковые массивы смогут 
обеспечить скорость передачи информации до 
40 Мбайт/сек, хотя здесь возможно некоторое сниже- 
ние скорости за счет влияния других факторов. 

В своем большинстве создатели систем дисковых 
массивов утверждают, что это не слишком трудная за- 
дача. Не так сложно получить систему, которая позво- 
лит вам преодолеть барьер скорости передачи данных 
в 30-40 Мбайт/сек. Однако, прежде чем приступить к 
созданию дисковых массивов, разработчики должны 
потратить массу времени на проведение серьезных ис- 
следований. 

Главная проблема заключается в выборе подходяще- 
го класса дискового массива. Различные классы масси- 
вов отличаются скоростью доступа к информации, 
скоростью передачи информации и требованиями к ее 
надежности. При оптимизации массива под конкрет- 
ную задачу инженер в первую очередь должен расста- 
вить приоритеты между всеми составляющими ее ас- 
пектами. 

Классы дисковых массивов 

В одном уважаемом издании Калифорнийского 
Университета дисковые массивы называются “резерви- 
рующими массивами недорогих дисков“ (Ребипбипі 
Аггауз оі Іпехрепзіѵе Эізкз — РАШ) и делятся на пять 
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ДИСКОВЫЕ МАССИВЫ 


классов. Исследование, первоначально выполненное 
для выяснения преимуществ дисковых массивов из 
5,25- 3,5- и даже 8-дюймовых дисков перед большими 
дисками, теперь служит руководством для определения 
типа стоящей перед разработчиком задачи: получение 
дополнительного объема, максимальной скорости пере- 
дачи информации или высоких характеристик ввода- 
вывода. 

Во всех пяти классах оцениваются преимущества 
дисковых массивов по сравнению с одиночными диска- 
ми в скорости передачи информации, высоких харак- 
теристиках ввода-вывода и надежности передаваемой 
информации, но различные классы ориентированы на 
разные задачи. В большинстве обзоров рассматривают- 
ся лишь три класса дисковых массивов — первый, 
третий и пятый — как наиболее распространенные. 

Дисковые массивы первого класса имеют полный 
дубликат каждого диска, обеспечивая максимальную, 
надежность хранения информации, но также и наи- 
высшую стоимость всей системы. Третий класс под- 
держивает максимальную скорость передачи данных, 
которая нужна при решении графических и других за- 
дач с большими файлами. Пятый класс дисковых мас- 
сивов ориентирован на напряженную работу с диска- 
ми и обеспечивает максимальную скорость доступа к 
информации. 

Необходимость удовлетворения множеству условий 
приводит к тому, что процесс выбора конфигурации 
дискового массива может стать крайне сложным. Раз- 
работчики компьютерной системы должны четко пред- 
ставлять себе, как она будет использоваться конечны- 
ми потребителями, и идти навстречу нуждам пользо- 
вателей. Некоторые изготовители высокопроизводи- 
тельных компьютеров покупают уже готовые дисковые 
массивы у других фирм, но многие все же предпочи- 
тают разрабатывать свои собственные, по большей 
части из-за сложности согласования характеристик 
массива с требованиями всей компьютерной системы. 

После того, как выбран класс дискового массива, 
начинается его разработка, в процессе которой прихо- 
дится решать значительно более сложные задачи, чем 
при создании одиночных дисковых систем. Разработ- 
чики должны учитывать многие особенности дисковых 
массивов, как например, необходимость использования 
блоков большего размера, отслеживания ошибок на от- 
дельном диске, в то время как идет чтение с других и 
т.п. 

Необходимо принимать во внимание особенности 
архитектуры компьютера, а чтобы получить высокие 
характеристики ввода-вывода, нужно оптимизировать 
размеры передаваемых файлов. Помимо этого, нужно 
должным образом подобрать характеристики использу- 
емых дисководов, чтобы достичь максимальной скоро- 
сти передачи данных. 

Разработчики дисковой системы должны позабо- 
титься также и о сбалансированности ее производи- 
тельности. Дисковые массивы способны передавать 
большие объемы данных, чем их может пропустить 
системная шина. Если у вас есть высокопроизводи- 


тельный дисковый массив, то управляющий компью- 
тер должен эффективно его использовать, чтобы полу- 
чить максимальные преимущества от его работы. С 
другой стороны, программное обеспечение должно ра- 
ботать таким образом, чтобы не ждать, пока диск за- 
кончит все операции ввода-вывода, а продолжать ре- 
шать в это время другие задачи. В применении к ми- 
никомпьютерам и суперкомпьютерам подобная поста- 
новка задачи часто требует внесения дополнительных 
изменений в операционную систему и прикладные 
программы. Например, для передачи больших блоков 
данных нужно удвоить размер блока от 512 Кбайт до 
1 Мбайта и т.д. 

Но в программном обеспечении персональных ком- 
пьютеров операционная система и прикладные про- 
граммы должны оставаться нетронутыми. Конечных 
пользователей этого класса компьютеров в значитель- 
но большей степени заботит возможность использова- 
ния стандартных пакетов прикладных программ, тогда 
как пользователи больших компьютеров привыкли 
постоянно изменять свои программы для получения 
наивысшей производительности. Это означает, что 
разработчики дисковых массивов для персональных 
компьютеров должны потратить гораздо больше уси- 
лий на то, чтобы преодолеть ограничения, налагаемые 
имеющимся программным обеспечением. 

Стандартные операционные системы персональных 
компьютеров — 008, 08/2, Ыоѵеіі, РС ІЫх и другие 
— не обязательно должны знать, как работать с дис- 
ками объема 4 или 5 Гбайт. Эти операционные систе- 
мы имеют некоторые свои особенности и ограничения, 
которые должны быть обойдены на аппаратном уров- 
не, с тем чтобы программное обеспечение оставалось 
нетронутым, а дисковый массив мог работать в пол- 
ную силу. Для этих целей используются специальные 
драйверы. 

Однако разработчики дисковых массивов говорят, 
что в скором времени даже для персональных компью- 
теров придется вносить определенные изменения в их 
операционные системы для более эффективной работы 
с дисковыми массивами. Многие операционные систе- 
мы для адресации дисков используют 32-битные слова, 
и, следовательно, они ограничены объемом 2 Гбайта. 
Если вы объединяете в массив пять дисков с объемом 
более 400 Мбайт каждый, то у вас появляется область 
дискового пространства, которую операционная систе- 
ма не может адресовать. И этот недостаток тоже дол- 
жен быть как-то устранен. 

Управление ошибками 

Поскольку дисковые массивы требуют лишь незна- 
чительных изменений в программном обеспечении, то 
для поддержки их высокой производительности необ- 
ходим очень интеллектуальный контроллер. В режиме 
записи контроллер делит файл на четыре или более 
частей, каждая из которых передается на свой диско- 
вод. Когда нужно прочитать данные, контроллер соби- 
рает их воедино и пересылает запрашивавшему ус- 
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тройству, которому нет дела до того, что данные были 
разделены. 

Для увеличения производительности контроллер 
должен так организовать процессы чтения и записи, 
чтобы какой-либо из дисководов не бездействовал, по- 
ка все другие заняты делом, а также чтобы головки 
дисков не совершали излишних перемещений. 

Контроллер должен просматривать все запросы на 
обращения к дисковому массиву. Затем он должен так 
распределить очередность выполнения этих запросов, 
чтобы загруженность дисков была равномерной, а их 
работа максимально эффективной. 

Поскольку на каждом диске содержится лишь часть 
данных, контроллер должен уметь быстро собирать 
эти части воедино, не забывая при этом следить за но- 
выми запросами и подготавливать их выполнение. Не- 
удивительно, что одной из ключевых задач контролле- 
ра дискового массива является эффективная и надеж- 
ная обработка ошибок. 

Необходимо иметь полную гарантию того, что все 
возможные ошибки будут обнаружены. В устройствах 
с несколькими дисками, объединенными в общий мас- 
сив, существует вероятность появления таких ситуа- 
ций, которые никогда не возникали прежде в однодис- 
ковых системах. Причем дисковые массивы могут ока- 
зать в таких случаях усиливающее воздействие и вы- 
звать лавину новых проблем. 

При разработке дисковых массивов делается попыт- 
ка, насколько это возможно, эмулировать одиночный 
диск в части системных обращений к нему. Это за- 
ставляет в значительной степени усложнять контрол- 
лер. Главная же задача — обеспечить высокую досто- 
верность передаваемой информации. Безусловно, все 
ошибки должны быть надежно устранены. 

Контроллеры должны отслеживать поврежденные 
места на дисках, отказы любого из дисководов, ошиб- 
ки плохого электрического контакта, а также обычные 
битовые ошибки записи и чтения. Основная проблема 
состоит в том, чтобы уведомить запрашивающее ус- 
тройство о возникшей неприятности. Большинство 
операционных систем предназначены для работы с 
одиночными дисками и не понимают тех ситуаций, 
когда один из дисков отказывает, но дисковая система 
в целом продолжает оставаться работоспособной. 

Другая сложная задача состоит в необходимости по- 
иска на дисках маленьких отрезков данных, которые 
не уместились в кэш-память при считывании концов 
файлов. При этом контроллер должен определить, где 
находится искомый блок, затем выяснить, свободен ли 
соответствующий канал и, наконец, считать данные с 
нужного диска, не затрагивая остальных. 

Серьезной задачей при поиске ошибок является не- 
обходимость осуществления этого поиска с минималь- 
ными затратами ресурсов. Использование алгоритмов 
более сложных, чем это необходимо в конкретной си- 
туации, требует дополнительного времени на обработ- 
ку ошибок. 

Пару лет назад разработчики дисковых массивов 
пришли к выводу, что нет необходимости производить 


одиночную или двойную коррекцию ошибок в опера- 
тивной памяти компьютера, поскольку в случае отказа 
одного из дисков восстановить данные не представляет 
большого труда. Контроль четности легко позволяет 
справиться с этим. 

Самый простой способ повышения надежности хра- 
нения информации на нескольких дисках — это до- 
бавление диска контроля четности. Когда теряются 
данные на одном из дисков, всегда есть достаточно 
информации на диске контроля четности и остальных 
дисках для надежного восстановления потерянных 
данных. 

Задача восстановления данных должна решаться 
совместными усилиями разработчиков дисковых мас- 
сивов и прочих системных средств. Некоторые конеч- 
ные пользователи хотят иметь возможность продол- 
жать работу одновременно с восстановлением потерян- 
ной информации на замененном диске. Это довольно 
сложная проблема, поскольку восстановление данных 
связано с перемещением сотен мегабайт с остальных 
дисков, каждый из которых содержит лишь часть не- 
обходимой 'информации. Тысячи актов чтения и запи- 
си не только предельно загружают все диски массива, 
но и требуют максимального напряжения от контрол- 
лера, который должен распределять время между 
процессом восстановления информации и обычной ра- 
ботой. 

Простейший способ восстановления потерянных 
файлов заключается во временной остановке сис- 
темы для загрузки информации на замененный 
диск. Но для пользователей, которые не могут по- 
зволить себе таких задержек, замена диска все 
равно приведет к временному снижению производи- 
тельности, поскольку контроллер должен одновре- 
менно с обслуживанием системных запросов вос- 
станавливать потерянные файлы. 

Другая задача разработки состоит в том, чтобы ре- 
шить, как быстро дисковый* массив должен восстанав- 
ливать потерянную информацию. Добавление лишних 
микропроцессоров в контроллер уменьшит время вос- 
становления, но и увеличит стоимость всей системы. 
Помимо этого, сложности программирования дополни- 
тельных процессоров и их синхронизации также при- 
бавят разработчикам лишнюю головную боль. 

Многое в обнаружении и обработке ошибок зависит 
от изготовителей контроллеров и прочих подсистем 
дисковых массивов, которые прилагают большие уси- 
лия для достижения гарантии надежной работы всей 
дисковой системы. Однако компоновщики конечных 
пользовательских систем также должны осуществлять 
подобное тестирование для получения уверенности в 
четкой работе массивов в конкретном аппаратном ок- 
ружении. 

Существуют тысячи ситуаций, при которых инфор- 
мация на дисках может быть потеряна, и тысячи 
способов устранения связанных с этим ошибок и 
восстановления данных. Разработчики предлагают 
множество аппаратных решений, гарантирующих 
сохранность данных без их резервного копирова- 
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5СО //с/, и Напіагех 5. ІІ. — 
нас объединяет ІІЫІХ 


Американская корпорация 8апіа Сгиг Орегаііоп ( 8СО Ы<1.) и 
советско-итальянское предприятие “Напіагех 8.1 У.” заключили 
соглашение о сотрудничестве , в результате которого “Напіагех 
8. II.” будет первой фирмой , представляющей продукцию корпо- 
рации в Советском Союзе. 

Корпорация 8апіа Сгиг известна во всем мире как лидер по разработке операционных 
систем ІЖІХ и соответствующего программного обеспечения. Начиная с 1986 года, 
компания ежегодно удваивает свой оборот - так велик спрос на системы ІПЧІХ. Гибкие, 
открытые для введения новых возможностей системы, существенно расширяют диапазон 
применения персональных компьютеров. В правительственых учреждениях, банках, 
научных институтах и предприятиях ІЛ9ІХ сегодня выполняет огромный объем работы. 
Операционные системы корпорации 8СО давно интересуют и советских специалистов. 
Но до сегодняшнего дня ІЛЧІХ либо был частью систем, сдаваемых под ключ западными 
фирмами, либо его отдельные версии распространялись нелегальным способом. 

Договор с “Напіагех 8.11.” даст возможность корпорации отрегулировать распределение 
операционных систем на советском рынке, а потребителям получить высококачествен- 
ную, зарекомендовавшую себя во всем мире продукцию. 

Более подробную информацию о системах ІШІХ, о возможности их приобре- 
тения Вы можете получить, обратившись в фирму “Напіагех 3.11.”. 

Адрес 117342 Москва, ул.Обручева, 36 
Телефон 334-29-74 
Телекс 412160 АИТАК 51Г 
Факс 420-22-50, 334-29-33 
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“Мы хотели осуществить качественно новый скачок, 
не вкладывая дополнительных средств в повышение 
производительности отдельных дисков 44 , — сказал 
Майк Перез (Міке Регех), технический директор 
Сошрая. 

В то время как фирма Сотрач определяла техни- 
ческую политику дисковых массивов для персональных 
компьютеров, Тапсіет Сотриіегз разрабатывала ее для 
систем непрерывного пользования, купив линию по 
производству дисковых массивов, а компания ЫСК. не- 
давно начала создание массивов для больших систем. 

Те, кто обычно ждет каких-либо шагов со стороны 
ІВМ, не будут слишком долго томиться в неопределен- 
ности: компания уже подписала соглашение с фирмой 
Махішит Вігаіе^у (8ап Лозе, СаШ.), производителем 
дисковых подсистем. Совместно они будут разрабаты- 
вать массивы, подключаемые к системам ІВМ через 
канал высокопроизводительного параллельного интер- 
фейса (НіРРІ — Ні^Н Регіогтапсе Рагаііеі Іпіегіасе), 
который становится универсальным для индустрии су- 
перкомпьютеров. 

Несмотря на то, что к дисковым массивам про- 
является большой интерес, некоторые изготовители 
контроллеров считают, что этот рынок не так уж 
велик. Ни компании Хуіо^ісз (Вигііп^іоп, Мазз), 
ни ІпІегрНазе Шаііаз) — два главных производи- 
теля дисковых контроллеров — не собираются вы- 


пускать контроллеры дисковых массивов. 

‘‘Все в первую очередь заинтересованы в прибылях, 
но всякий интерес тут же пропадает, как только речь 
заходит об увеличении себестоимости продукции в два 
раза. Производители не хотят увеличивать себестои- 
мость более чем на 10 процентов. Как только кто-либо 
достигнет подобных результатов, рынок будет готов 
принять дисковые массивы 44 , — говорит Эрнст Годен 
(Егпезі Соёзеу), директор по маркетингу компании 
ІпіегрНазе. 

Но, невзирая на то, что рынок контроллеров диско- 
вых массивов может быть не слишком большим, про- 
изводители как самих контроллеров, так и дисковых 
подсистем твердо намерены продолжать совершенство- 
вать эту технологию. 

Современный рынок дисковых средств совершенно 
определенно наметил дисковые массивы в качестве 
своих главных перспектив на ближайшее время. На 
сегодняшний день не осталось ни одного серьезного 
производителя вычислительных систем, который бы не 
проводил исследования по включению дисковых мас- 
сивов в состав своих будущих разработок. 

А Синев 

По материалам: 

Еіесігопіс Еп^іпеегіп^ Тітез, ЫоѵетЬег 5, 1990. 


Плетью обуха не перешибешь. 

Несмотря на отсутствие какой бы то ни было правовой 
защиты от нелегального копирования и отсутствие каких 
бы то ни было штрафных санкций за использование 
нелегального программного обеспечения, корпорация 
МісгозоГі намерена поставлять вторую редакцию 
локализованного интегрированного пакета ѴЮККЗ 2.0 без 
программной защиты. 

Для справки, первая редакция пакета поставлялась с 
системой защиты, позволяющей использовать рабочую 
копию пакета не более чем на одном компьютере од- 
новременно. При переносе рабочей копии на другой ком- 
пьютер существующая копия удалялась. 

Представители фирмы утверждают, что отказ от про- 
граммной защиты вызван желанием устранить дискомфорт 
потребителя, вызванный возможностью утраты пакета при 
сбое жесткого диска, повреждении оригинальной дискеты 
или заражении. Кроме того, они признались, чтб 
установка защиты на первую редакцию пакета была 
ошибкой. 

Во второй редакции исправлен ряд недостатков первой, 
в том числе некорректная работа режима рисования 
псевдографики. 

Локализованный интегрированный пакет Ж)ККЗ за- 
воевывает все большую популярность и достаточно быстро 
распространяется по стране, но не приносит ни копейки 
прибыли фирме-разработчику. Автором одной из вскрытых 
копий злые языки называют известного программиста 
А.Чижова (одного из авторов резидентного руссификатора 
РусскоеСлово, защищенного программой датской фирмы 
ЫпкСотри(ег), если это верно, то остается надеяться, что 
он сделал это из спортивного интереса. 

Вызывает большое сомнение, что продажа на советском 
рынке незащищенного пакета, в надежде на честную игру 


советских пользователей, принесет фирме дивиденды и 
следовательно желание локализовать новые программные 
продукты. 

Следует обратить внимание на то обстоятельство, что 
корпорация МісгозоК прекратила поставки локализованной 
версии ДОС 4.01 и в СССР торгует только лицензиями на 
производство. 

В стране, где обману учат сказки, а воровство почита- 
ется, есть только один путь для нормальной коммерческой 
деятельности в области программного обеспечения — это 
снижение цены до такого уровня, когда выгоднее будет 
купить, чем пользоваться нелегальными копиями. 

В цивилизованных странах купить, это значит: 
получить документацию; 

получить запечатанный пакет дистрибутивных дисков; 
получать необходимую информацию и консультации; 
присутствовать на выставках и семинарах; 
заменять старые версии на новые за треть или четверть 
цены; 

приобретать новые продукты по сниженным ценам. 

Много ли в СССР организаций — распространителей 
программного обеспечения — предоставляют подобный 
сервис? Большинство направляет свои доходы по 
дилерскому проценту куда угодно, но не на поддержку 
пользователей и развитие дилерской службы. 

Если корпорации МісговоГі удастся открыть 

производство программных продуктов в СССР, 
реализовывать их за рубли (за приемлемую цену) и орга- 
низовать сеть поддержки, тогда покупать будет выгодно, а 
нынешняя цена пакета М8ЛѴОКК5 2.0 — 350 долл., не 
оставляет никаких иллюзий на счет путей дальнейшего 
распространения второй редакции этого пакета. 

Ые^зЬуІез Ые и* ЫеЬюгк, 
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5СО Нс /. и Напіагех 5.ІІ. — 
нас объединяет ІІЫІХ 


Американская корпорация 5ап1а Сгиг Орегаііоп ( 8СО ЫЛ.) и 
советско-итальянское предприятие “Напіагех 5.1 заключили 
соглашение о сотрудничестве , в результате которого “Напіагех 
5.11.” будет первой фирмой , представляющей продукцию корпо- 
рации в Советском Союзе. 

Корпорация Запіа Сгиг известна во всем мире как лидер по разработке операционных 
систем ІЛЧІХ и соответствующего программного обеспечения. Начиная с 1986 года, 
компания ежегодно удваивает свой оборот - так велик спрос на системы ІЖІХ. Гибкие, 
открытые для введения новых возможностей системы, существенно расширяют диапазон 
применения персональных компьютеров. В правительственых учреждениях, банках, 
научных институтах и предприятиях ІЛЧІХ сегодня выполняет огромный объем работы. 
Операционные системы корпорации 8СО давно интересуют и советских специалистов. 
Но до сегодняшнего дня ІЖІХ либо был частью систем, сдаваемых под ключ западными 
фирмами, либо его отдельные версии распространялись нелегальным способом. 

Договор с “Напіагех 8.11.” даст возможность корпорации отрегулировать распределение 
операционных систем на советском рынке, а потребителям получить высококачествен- 
ную, зарекомендовавшую себя во всем мире продукцию. 

Более подробную информацию о системах ІЖІХ, о возможности их приобре- 
тения Вы можете получить, обратившись в фирму “Напіагех 3.11.”. 

Адрес 117342 Москва, ул.Обручева, 36 

Телефон 334-29-74 

Телекс 412160 АЫТАК 51/ 

Факс 420-22-50, 334-29-33 
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Мы и обернуться не успеем, а уже нава- 
лит больше прежнего... 

А. и Б.Стругацкие “Град обреченный" 

Стоит мне что-нибудь проглотить, 
как тут же происходит что-нибудь ин- 
тересное. Посмотрим, что будет на 
этот раз! 

Л.Кэролл “Алиса в стране чудес" 


КОМПЬЮТЕРНЫЕ 

вирусы : 

ПРЕ ДВА РИТЕЛЬНЫЕ 
СООБРАЖЕНИЯ 


По поводу термина 

Первые исследования саморазмножающихся искус- 
ственных конструкций проводились в середине ны- 
нешнего столетия: в работах фон Неймана, Винера и 
др. дано определение и проведен математический ана- 
лиз конечных автоматов, в том числе самовоспроизво- 
дящихся. Термин “компьютерный вирус" появился по- 
зднее — официально считается, что его впервые упот- 
ребил сотрудник Лехайского университета (США) 
Фред Коэн в 1984 году на 7-й конференции по безо- 
пасности информации, проходившей в США. С тех 
пор прошло немало времени, острота проблемы виру- 
сов нисколько не снизилась, однако строгого определе- 
ния, что же такое компьютерный вирус, так и не да- 
но, несмотря на неоднократные попытки дать такое 
определение. Поэтому я наберусь смелости и попыта- 
юсь сформулировать собственное определение. 

Компьютерным вирусом называется программа, ко- 
торая может создавать свои копии (не обязательно 
полностью совпадающие с оригиналом) и внедрять их 
в файлы, системные области компьютера, сети и так 
далее. При этом копии сохраняют способность даль- 
нейшего распространения. 

По поводу самих вирусов и их авторов 

Сам я не написал ни одного вируса, не знаком ни с 
одним из авторов вирусов, и, следовательно, мои сооб- 
ражения по этому поводу могут быть лишь чисто тео- 
ретическими. 


Так кто же пишет вирусы? На мой взгляд, основ- 
ную массу вирусов создают люди, которые только что 
изучили язык ассемблера, хотят попробовать свои си- 
лы, но не могут найти для них более достойного при- 
менения. Из под пера подобных “умельцев" часто вы- 
ходят либо модификации “классических" вирусов, ли- 
бо вирусы крайне примитивные и с большим числом 
ошибок (такие вирусы я называю “студенческими"). 

Самую опасную группу составляют “профессио- 
нальные" вирусы. Эти тщательно продуманные и от- 
лаженные программы создаются профессиональными, 
нередко очень талантливыми программ иста ми. Такие 
вирусы зачастую используют достаточно оригинальные 
алгоритмы, недокументированные и мало кому извест- 
ные способы проникновения в системные области. Ча- 
сто “профессиональные" вирусы выполнены по техно- 
логии “стеле". Для меня остаются загадкой причины, 
которые могут заставить человека направить свои не- 
малые способности на такую бессмысленную работу. 
Не исключено, что некоторые из таких людей — неу- 
дачники, не сумевшие более эффективно воспользо- 
ваться своими знаниями. 

Умрет ли М8-И08 от вирусной болезни? 

По моим сведениям, в развитых странах проблема 
компьютерных вирусов не является столь острой, так 
как там в значительно меньшей степени распростра- 
нено пиратское копирование программного обеспече- 
ния, гораздо более активно действуют фирмы, специа- 
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ПРЕДВАРИТЕЛЬНЫЕ СООБРАЖЕНИЯ 


Таблица 1. Свойства и характеристики файловых и файлово-загрузочных вирусов. 


Имя 

Резидент- 

ность 

Метод 

зараж 

Способ инфици- 
рования памяти 

Обе 

РеасЮп Іу 

)абОТКе 

РТіте 

ІпТ 24 

Вызываемые 

эффекты 

АтзТ габ-277 

- 

РІИО 

- 

- 

- 

_ 

Ег 

АтзИ гаЦ-299 

- 

РІИО 

- 

- 

- 

- 

ѴЕг 

АтзТ гасІ-345 

- 

РІЫй 

- 

- 

- 

- 

ѴЕг 

АтзТ гаЦ-740 

- 

РІИО 

- 

- 

- 

- 

ѴЕг 

АтзТ гаЦ-847 

- 

РІИЭ 

- 

- 

- 

- 

ѴЕг 

АтзТгасІ-852 

- 

РІИй 

- 

- 

- 

- 

ѴЕг 

АпТ і -Раз-400 

_ 

РІИО 

- 

4- 

4- 

- 

Н 

АпТ і-Раз-440 

- 

РІИО 

- 

4- 

4* 

- 

Н 

АпТ і -Раз-480 

- 

РІИО 

- 




Н 

АпТ і -Раз-529 

- 

РІИО 

- 




Н 

АпТ і-Раз-605 

- 

РІИО 

- 

- 

“ 

4- 

Н 

Аргі 1 ІзТ СОМ 

+ 

ІИТ 

КЕЕР 

- 

4- 

4- 

V 

Аргі 1 ІЗТ ЕХЕ 

+ 

ІИТ 

КЕЕР 

- 

ч» 

4- 

ѴЕг 

СазсасІе-1701 


ІИТ 

мсв* 

4- 

4- 

_ 

V 

СазсаОе-1704 

+ 

ІИТ 

мсв* 

4- 

4- 

- 

V 

ЕсШіе-651 

♦ 

ІЫТ 

мсв 

4- 

+ * 

4- 

- 

ЕсЮіе-1800 

♦ 

ІИТ 

мсв 

+ 

4- 

4- 

н 

ЕсШіе-2000 

+ 

ІИТ 

мсв 

+ 

4-* 

♦ 

н 

ЕсШіе-2100 

+ 

ІИТ 

мсв 

4- 

4-* 

4- 

н 

Зегиза Іет 

+ 

ІИТ 

КЕЕР 

4- 

4» 

4- 

НЕ г 

РіітапсНи-2080 

+ 

ІМТ 

КЕЕР 

4- 

4» 

4- 

ѴЕг 

Ку 1 іе-2272 

.4- 

ІИТ 

КЕЕР 

4* 

- 

4- 

МЕг 

5ип0ау-1631 

4- 

ІМТ 

КЕЕР 

4- 

4- 

4- 

НЕг 

Таіѵ/ап-2900 

4- 

ІМТ 

КЕЕР 

4- 

- 

4- 

НМЕг 

Нутп-1865 

4* 

ІМТ 

мсв 

4- 

4- 

_ 

ѴМН 

Нутп-1962 

4- 

ІМТ 

мсв 

+ 

+ 

4- 

ѵмн 

Нутп-2144 

4- 

ІМТ 

мсв 

4- 

4- 

4- 

ѴМН 

МигрЬу-1277 

4- 

ІМТ 

мсв 

- 

4- 

4- 

м 

МигрЬу-1521 

4- 

ІМТ 

мсв 

- 

4- 

4- 

V 

РЬоеп іх 

+ 

ІМТ* 

мсв 

+ 

+ 

4- 

н 

Еѵі 1 

4* 

ІМТ* 

мсв 

+ 

+ 

4- 

н 

Ргоиб 

4- 

ІМТ* 

мсв 

4* 

4* 

4- 

н 

8ага*ода-632 

4- 

ІМТ 

мсв 

- 

- 

- 

- 

8агаТода-642 

4- 

ІМТ 

мсв 

- 

- 

- 

СИ 

8агаТ: ода-656 

+ 

ІМТ 

мсв 

- 

— 

- 

сн 

8ѴС-1689 

4- 

ІМТ 

мсв 

♦ 

4- 

4- 

_ 

8ѴС-1740 

4- 

ІМТ 

мсв 

4- 

4- 

4- 

- 

8ѴС-3103 

4- 

ІМТ 

мсв 

4- 

4- 

♦ 

- 

Тіпу-133 

4- 

ІМТ 

* 

- 

- 

_ 

- 

Тіпу-134 

4- 

ІМТ 

* 

- 

- 

- 

- 

Тіпу-138 

4- 

ІМТ 

• * 

- 

- 

- 

- 

Т іпу-143 

+ 

ІМТ 

* 

- 

- 

- 

- 

Тіпу-154 

+ 

ІМТ 

* 

- 

- 

- 

- 

Тіпу-156 

4- 

ІМТ 

* 

- 

- 

- 

- 

Т іпу-158 

+ 

ІМТ 

* 

- 

- 

- 

- 

Т іпу-159 

4* 

ІМТ 

* 

- 

- 

- 

- 

Тіпу-160 

♦ 

ІМТ 

* 

- 

- 

- 

- 

Тіпу-167 

4- 

ІМТ 

* 

- 

- 

- 

- 

Т іпу-198 

4» 

ІМТ 

* 

- 

- 

- 

- 

Ѵ-1024-а 

+ 

ІМТ 

мсв 

4- 

+ 

4- 

V 

Ѵ-1024-Ь 

4- 

ІЫТ 

м'св 

+ 

4» 

4- 

V 

Ѵ-600 

4» 

ІМТ 

мсв 

+ 

+ 

+ 

_ 

ѴогопегЬ-1600 

4- 

ІМТ 

мсв 

+ 

+ 

+ 

Ег 


лизирующиеся на произ- 
водстве антивирусной 
продукции, много раз- 
нообразной литературы, 
посвященной данному 
вопросу. В результате 
большинство пользовате- 
лей знают, что такое 
вирус и какие могут 
быть последствия от его 
“визита", готовы к 
борьбе с вирусом, но 
“живьем" ни одного ви- 
руса не видели уже 
очень давно. 

В нашей же стране все 
обстоит гораздо более се- 
рьезно. Основным источ- 
ником приобретения но- 
вых программных про- 
дуктов у нас является их 
бесконтрольное копиро- 
вание; персональные 
компьютеры очень часто 
используются в “много- 
персональном" режиме. 

Для распространения ви- 
руса это самая благодат- 
ная среда. В результате в 
учебных институтах, в 
организациях (иногда до- 
статочно серьезных) 
факт заражения вирусом 
вполне обычное явление, 
что-то вроде насморка. 

Такое “привыкание" мо- 
жет кончиться плачевно 
при заражении каким- 
либо опасным вирусом. 

Хотя, если на машине 
нет ничего, кроме 005 
и большого числа игр, 
то вируса можно не 
бояться — невелика по- 
теря (кстати, ситуация 
очень распространен- 
ная). 

Следует отметить 

быстрый рост числа ком- 
пьютерных вирусов со- 
ветского производства 
(по моим данным, общее 
число на 1989г. — 1, на 
август 1990г. — 3 или 4, сентябрь — около 6, ок- 
тябрь — около 15, ноябрь — около 20, затем я сбился 
со счету). Это естественно — ведь когда платят лишь 
за присутствие на работе, есть возможность занимать- 
ся всем, чем угодно (попробуйте возразить, что, мол, 
это очень редкая ситуация), а ничем полезным или 


прибыльным заниматься не хочется, то от нечего де- 
лать можно попробовать запрограммировать вирус 
(тем более, что в нашей стране это пока не пре- 
следуется уголовно). К тому же программирование все 
больше и больше превращается из искусства в ремес- 
ло, а среди программистов все реже встречаются “ин- 
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Таблица 1. Свойства и характеристики файловых и файлово-загрузочных вирусов. КЛАССИФИКАЦИЯ 

( Продолжение ) КОМПЬЮТЕРНЫХ 

ВИРУСОВ 


Ѵіеппа-348 

- 


- 

+ 

+* 

- 

н 

Ѵіеппа-353 

- 

РІЫ0 

- 

+ 

+* 

- 

н 

Ѵіеппа-367 

- 

РІШ 

- 

+ 

♦* 

- 

н 

Ѵіеппа-435 


РІИ0 

- 

+ 

+* 

- 

н 

Ѵіеппа-507 

- 

РІИ0 

- 

♦ 

+* 

- 

- 

Ѵіеппа-534 

- 

РІИ0 

- 

+ 

+* 

- 

- 

Ѵіеппа-623 

- 

РІИ0 

— 

+ 

+* 

+ 

н 

Ѵіеппа-627 

- 

РІИ0 

- 

+ 

+* 

- 

- 

Ѵіеппа-644 

- 

РІМ 

- 

+ 

* 

- 

- 

Ѵіеппа-648 

- 

РІМО 

- 

+ 

+* 

- 

н 

Ѵіеппа-757 

- 

РІИ0 

- 

+ 

+* 

+ 

V 

Ѵіеппа-776 

- 

РІМО 

- 

+ 

♦* 

+ 

V 

Від РіТег 

_ * 

РІМО 

- 

+ 

+* 

- 

V 

ѴАС8І МА-04 

+ 

ІМТ 

мсв 

+ 

_ 

+ 

м 

ѴАС8І МА-05 

+ 

ІМТ 

мсв 

+ 

- 

+ 

м 

ѴАС8І МА-06 

+ 

ІМТ 

мсв 

+ 

- 

+ 

м 

ѴАС8І МА-10 

+ 

ІМТ 

мсв 

+ 

+ 

+ 

м 

Ѵапкее - 17 

+ 

ІМТ 

мсв 

+ 

+ 

+ 

м 

Ѵапкее - 18 

+ 

ІМТ* 

мсв 

♦ 

+ 

+ 

м 

Ѵапкее - 19 

+ 

ІМТ 

мсв 

+ 

+ 


м 

Ѵапкее - 21 

-і- 

ІМТ 

мсв 

+ 

+ 

+ 

м 

Ѵапкее - 22 

+ 

ІМТ 

мсв 

+ 

+ 

+ 

м 

Ѵапкее - 26 

+ 

ІМТ 

ИСВ 

♦ 

+ 

♦ 

м 

Ѵапкее - 27 

-і» 

ІМТ 

мсв 

+ 

+ 

+ 

м 

Ѵапкее - 29 

+ 

ІМТ 

мсв 

♦ 

+ 

+ 

м 

Ѵапкее - 2А 

+ 

ІМТ 

мсв 

+ 

+ 

+ 

м 

Ѵапкее - 2С 

♦ 

ІМТ 

мсв 

+ 

+ 

+ 

м 

Ѵапкее - 20 

+ 

ІМТ 

мсв 

♦ 

♦ 

+ 

м 

Ѵапкее - 2Е 

+ 

ІМТ 

мсв 

+ 

+ 

+ 

м 

Ѵапкее ’ -1905 

+ 

ІМТ 

мсв 

+ 

♦ 

+ 

м 

Ѵапкее ’ -1049 

♦ 

ІМТ 

мсв 

+ 

♦ 

+ 

- 

УапЗНогг-1624 

- 

РІМО 

_ 

_ 

+ 

_ 

* 

Ѵап$ЬоП-1961 

- 

РІМО 

- 

- 

+ 

- 

м 

512 (вер а -Р) 

♦ 

ІМТ 

ВиРРег 

- 

♦* 

+ 

- 

А 1 арата 

♦ 

ІМРІ 

мсв 

+ 

+ * 

♦ 

V 

АТТЕМТІОМ 

+ 

ІМТ 

мсв 

+* 

- 


Ег 

Вебе 

_ * 

РІМО 

* 

- 

- 

■ - 

V 

ОаРасгіте 

- 

РІМО 

- 

+ 

+ 

- 

ѵн 

иокег-01 

+ 

ІМТ 

мсв 

+ 

+ 

+ 

V 

Кетегоѵа 

- 

РІМО 

- 

- 

- 

- 

* 

Кики-448 

- 

РІМО 

- 

+ 

* 

- 

нѵ 

1_ебідЬ 

+ 

ІМТ 

мсв 

- 

- 

- 

ѵ н 

ІіЬегТу 

♦ 

ІМТ 

мсв 

- 

- 

♦ 

н 

ЮѵеСМІсІ 

♦ 

ІМТ 

ІпРТаЬ Іе 

- 

- 

+ 

н 

102-1023 

+ 

ІМТ 

мсв 

А 

- 

♦ 

нѵ 

Міпзк-1075 

♦ 

ІМТ 

мсв 

+ 

- 

+ * 

НЕ г 

Мі ггог 

♦ * 

ІМТ 

? 

- 

- 

- 

ѵн 

МСТІІ-273 

- 

РІМО 

- 

- 

- 

- 

- 

МИІ-830 

♦ 

ІМТ 

мсв 

+ 

- 

- 

н 

РеРегбигд 

+ 

ІМТ 

КЕЕР 

+ 

+ 

+ 

- 

ВС-492 

+ 

ІМТ 

ІпТТаб Іе 

— 

— 

— 

н 

Зтаі 1-144 

+ 

ІМТ 

ІпРТаб Іе 

- 

- 

- 

- 

8у Іѵіа 

- 

РІМО 

- 

- 

- 

+ 

- 

ѴСОММ-637 

— 

РІМО 

- 

+ 

+ 

- 

* 

Ѵ-516 

+ 

ІМТ 

ВиРРег 

♦ 

+ 

♦ 

СИ 

Ѵ-707 

+ 

ІМТ 

мсв* 

+ 

+ 

- 

V 

Ѵ-905 

+ 

ІМТ 

мсв 

♦ 

+ 

♦ 

V* 

ИізЬ-1024 

+ 

ІМТ 

мсв 

♦ 

- 

+ 

н 

4096 

♦ 

ІМТ 

мсв* 

+ 

+* 

+ 

ѵн 


теллектуалы 44 и все чаще ремесленники-“таперы 44 , что 
не может не сказаться на “индексе порядочности 44 сре- 
ди представителей этой профессии. В результате ком- 
пьютерное хулиганство процветает (именно хулиган- 
ство, поскольку создавать вирусы и мочиться в лиф- 
те — поступки одного порядка). 


Вирусы можно разде- 
лить на классы по следу- 
ющим признакам: 

— по среде обитания ви- 
руса; 

— по способу заражения 
среды обитания; 

— по деструктивным воз- 
можностям. 

По среде обитания 
различают вирусы сете- 
вые, файловые и загру- 
зочные. Сетевые вирусы 
распространяются по 
компьютерной сети, фай- 
ловые внедряются в вы- 
полняемые файлы, загру- 
зочные — в загрузочный 
сектор диска (Вооі-сек- 
тор) или в сектор, содер- 
жащий системный за- 
грузчик винчестера 

(Мазіег Вооі Кесогб). Су- 
ществуют сочетания — 
например, файлово-за- 
грузочные вирусы, зара- 
жающие и файлы и за- 
грузочные сектора дис- 
ков. Кроме того, по сети 
могут распространяться 
вирусы любых типов. 

Способы заражения 
делятся на резидентный 
и нерезидентный. Рези- 
дентный вирус при ин- 
фицировании компьюте- 
ра оставляет в оператив- 
ной памяти свою рези- 
дентную часть, которая 
затем перехватывает об- 
ращение операционной 
системы к объектам зара- 
жения и внедряется в 
них. Резидентные вирусы 
находятся в памяти и 
остаются активными 
вплоть до выключения 
или перезагрузки компьютера. Нерезидентные вирусы 
не заражают память компьютера и являются активны- 
ми ограниченное время. Некоторые вирусы оставляют 
в оперативной памяти небольшие резидентные про- 
граммы, которые не распространяют вирус. Такие ви- 
русы считаются нерезидентными. 
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Таблица 1. Свойства и характеристики файловых и файлово-загрузочных вирусов. 

(продолжение). 



8ѴС-1689 1689 (699Н) СЕ е 1024 (400Н) <С< (Р943Ю, 
8ѴС-1740 1740 (6ССЬ) СЕ е 1024 (400Ь) <С< (Р910Н). 
8ѴС-3103 3103 (С1РН) СЕ е 3103 (СІРЬ) <С< (ЕОЕІЬ), 











































Таблица 1. Свойства и характеристики файловых и файлово-загрузочных вирусов. 

(продолжение). 
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ПРЕДВАРИТЕЛЬНЫЕ СООБРАЖЕНИЯ 

По деструктивным возможностям вирусы мож- 
но разделить на: 

а) безвредные, никак не влияющие на работу 
компьютера (кроме уменьшения свободной па- 
мяти на диске в результате своего распростране- 
ния); 

б) неопасные, влияние которых ограничивается 
уменьшением свободной памяти на диске и гра- 
фическими, звуковыми и прочими эффектами; 

в) опасные вирусы, которые могут привести к се- 
рьезным сбоям в работе компьютера; 

г) очень опасные, которые могут привести к поте- 
ре программ, уничтожить данные, стереть необ- 
ходимую для работы компьютера информацию, 
записанную в системных областях памяти, и да- 
же способствовать ускоренному износу движу- 
щихся частей механизмов (например, I головок 
винчестера). 

СПОСОБЫ 

РАСПРОСТРАНЕНИЯ 

И СТРУКТУРА 
КОМПЬЮТЕРНЫХ ВИРУСОВ 


Ниже приводятся примеры структур и способов 
распространения файловых и загрузочных виру- 
сов. 

Файловые вирусы 

Вирус может внедриться в файлы трех типов — 
командные файлы (ВАТ), загружаемые драйверы 
(8ѴЗ, в том числе ІО.ЗѴ5 и М5О03.5Ѵ5) и вы- 
полняемые двоичные файлы (ЕХЕ и СОМ). Воз- 
можно внедрение вируса в файлы данных, но эти 
случаи возникают либо в результате ошибки ви- 
руса, либо при проявлении вирусом своих агрес- 
сивных свойств. Конечно, возможно существова- 
ние вирусов, заражающих файлы, содержащие 
исходные тексты программ, библиотечные или 
объектные модули, но подобные способы рас- 
пространения вируса слишком экзотичны и в 
дальнейшем не рассматриваются. 

Мне известны два ВАТ-вируса. Они не пред- 
ставляют интереса, так как достаточно примитив- 
ны, очень просто обнаруживаются и удаляются. 

Вирусы, внедряющиеся в 8Ѵ5-файл, приписы- 
вают свои коды к телу файла и модифицируют 
его заголовок так, что 005 рассматривает инфи- 
цированный файл как цепочку из двух (или бо- 
лее) драйверов. Такой вирус может быть чрезвы- 
чайно опасным и живучим, так как внедряется в 
оперативную память при загрузке операционной 
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системы раньше любой антивирусной программы, если 
она, конечно, тоже не является драйвером. 


Незараженный 
файл драйвера 


Зараженный 
файл драйвера 


Заголовок 

Драйвер 


Заголовок 

Драйвер 


Заголовок 

Вирус 


Аналогично вирус может записать свои коды в на- 
чало драйвера, а если в файле содержится несколько 
драйверов, то и в середину файла. 

Выполняемые двоичные файлы, имеющие форматы 
СОМ или ЕХЕ, отличающиеся заголовком и способом 
запуска программ на выполнение. Расширение имени 
файла (“.СОМ“ или “.ЕХЕ“) не всегда соответствует 
действительному формату файла, что, правда, никак 
не влияет на работу программы. Файлы СОМ и ЕХЕ 
заражаются по-разному, следовательно, вирус должен 
отличать файлы одного формата от файлов другого. 
Вирусы решают эту задачу двумя способами: одни 
анализируют расширение имени файла ( и .СОМ“ или 
“.ЕХЕ“), другие — заголовок файла. Первый способ 
далее будет называться заражением .СОМ- (или 
ЕХЕ-) файлов, второй — заражением СОМ- (или 
ЕХЕ-) файлов (обратите внимание на точку перед 
расширением!). В большинстве случаев вирус инфици- 
рует файл корректно, то есть по информации, содер- 
жащейся в теле вируса, можно полностью восстано- 
вить зараженный файл. 

Файловые вирусы при распространении внедряются 
в тело заражаемого файла: в его начало, конец или се- 
редину. 

Существует несколько способов внедрения вируса в 
середину файла: он может быть скопирован в таблицу 
настройки адресов, в область стека, может “раздви- 


Таблица 2. Свойства и характеристики загрузочных вирусов. 


нуть“ файл или переписать часть файла в его конец, 
а свои коды в освободившееся место, и так далее. Кро- 
ме того, копирование вируса в середину файла воз- 
можно в результате ошибки вируса — в этом случае 
файл может быть необратимо испорчен. 

Известны два способа внедрения вируса в начало 
файла. Первый способ заключается в том, что вирус 
переписывает начало заражаемого файла в его конец, 
а сам копируется в освободившееся место. При зара- 
жении файла вторым способом вирус создает в опера- 
тивной памяти свою копию, дописывает к ней заража- 
емый файл и сохраняет полученную конкатенацию на 
диск. 


Файл 

а 


г “1 

Свободно 

б) 

Вирус 




Файл 


Файл 



— > 





Внедрение вируса в начало файла 
первым способом 


— 

а) 

г 

б) 

— 

Файл 

— 1 

Свободно 


Вирус 

— 

I— > 
1— 

Файл 


Файл 


Имя 

Длина 

Заражаемые 

объекты 

Уменьшение 
памяти (Кб) 

Число сбойных 
секторов 

Вызываемые 

эффекты 

Вгаіп/Азбаг 

3072 

(С006) 

Р 

7 

6 

С6 

Вгаіп/біпдароге 

3072 

(С006) 

Р 

7 

6 

С6 

Ріпд-Ропд 

1024 

(4006 ) 

РВ 

2 

2 

V 

Наскеб Ріпд-Ропд 

1024 

(4006) 

РВ 

2 

2 

Н 

Ріпд-Ропд тобі^уеб 

1024 

(4006) 

РВ 

2 

2 

V 

Зтопе 

512 

( 2006 ) 

РМ 

2 

0 

ѴЕг 

ЗТопе НозТоѵ 

512 

( 2006 ) 

РМ 

2 

0 

НЕ г 

Эеп 2ик 

5120 

(14006) 

Р 

7 

0 

ѴЕгСб 

Оізк Кі 1 Іег 

3072 

(С006) 

РВ 

8 

Нагб ”0 , Т Іор-6 

НѴ 

бозбі 

5120 

(14006) 

РМ 

6 

0 

V 

1_іЬегТу 

4608 

(12006) 

Р (Рііе) 

10 

0 

Н* 

Рг іпТбсгееп 

512 

(2006) 

РВ 

2 

0 

Ег * 


Внедрение вируса в начало файла 
вторым способом 

Наиболее распространенным способом внедрения 
вируса в файл является дописывание вируса в конец 
этого файла. При этом вирус изменяет начало файла 
таким образом, что первыми исполняемыми команда- 
мй программы, содержащейся в файле, являются ко- 
манды вируса. В СОМ-файле в большинстве случаев 
это достигается изменением его первых трех (или бо- 
лее) байтов на коды инструкции ІМР Ьос_Ѵіги5 (пере- 
дача управления на тело вируса); ЕХЕ-файл либо пе- 
реводится в формат СОМ-файла и затем заражается 

как СОМ-файл, 
либо выполняет- 
ся модификация 
заголовка файла. 
В заголовке 

ЕХЕ-файла из- 
меняются значе- 
ние стартового 
адреса (С5:ІР) и 
значение длины 
выполняемого 
модуля (файла), 
реже — регист- 
ры-указатели на 
стек (53:5Р), 
контрольная 
сумма файла и 
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др. Дополнительно к этому длины файлов перед зара- 
жением могут увеличиваться до значения, кратного 
параграфу (16 байт). 


СОМ-файл ЕХЕ-файл 


— 


1 — 

Заголовок 


Программа 


Программа 


— 

1 

V 



Вирус 

Стартовый 

— 

— > 


адрес 

> 

Вирус 






Внедрение вируса в конец файла 


СТАНДАРТНЫМ СПОСОБОМ ЗАРАЖЕНИЯ далее бу- 
дет называться такой способ, при котором вирус допи- 
сывается в конец файла и изменяет у СОМ- файла 
первые 3 байта иМР Ьос Ѵігиз), а у ЕХЕ-файла — 
заголовок. 

Вирус, после передачи ему управления, совершает 
следующие действия (приведен список наиболее об- 
щих действий вируса при его выполнении; для кон- 
кретного вируса список может быть дополнен, пункты 
могут поменяться местами и значительно расширить- 
ся): 

а) восстанавливает программу (но не файл) в исход- 
ном виде (у СОМ-программы восстанавливаются пер- 
вые 3 байта, у ЕХЕ-программы вычисляется истин- 
ный стартовый адрес); 

б) если вирус резидентный, то он проверяет оператив- 
ную память на наличие своей копии и инфицирует 
память компьютера, 
если копия вируса не 
найдена. Если вирус 
нерезидентный, то он 
ищет незараженные 
файлы в текущем и 
(или) корневом ката- 
логе, в каталогах, от- 
меченных командой 
РАТН, и т.д., а затем 
заражает обнаружен- 
ные файлы; 

в) выполняет, если они 

есть, дополнительные 
функции: какие-либо 

деструктивные дей- 
ствия, графические 
или звуковые эффекты 
и так далее. (Дополни- 
тельные функции ре- 
зидентного вируса мо- 
гут вызываться спустя 
некоторое время после 
активизации в зависи- 
мости от текущего вре- 
мени, конфигурации 
системы, внутренних счетчиков вируса или других 
условий. В этом случае вирус при активизации обра- 


батывает состояние системных часов, устанавливает 
свои счетчики и т.д.); 

г) возвращает управление основной программе. 

Действия, описанные в пунктах а) — г), далее будут 
упоминаться как СТАНДАРТНЫЕ. 

При восстановлении программы в первоначальном 
виде, вирус использует информацию о программе, сох- 
раненную в теле вируса при заражении файла. Это 
может быть длина файла, первые три байта файла в 
случае СОМ-файла или несколько байтов заголовка в 
случае ЕХЕ-файла. 

Известны два способа проверки резидентным виру- 
сом наличия своей копии в памяти компьютера. Пер- 
вый заключается в том, что вирус вводит новую функ- 
цию некоторого прерывания, действие которой заклю- 
чается в возврате значения “я здесь". При старте ви- 
рус обращается к ней, и, если возвращенное значение 
совпадает со значением "я здесь", то делается вывод, 
что память компьютера уже заражена и повторного 
заражения не производится. При проверке вторым 
способом вирус просто сканирует память компьютера. 
Оба способа могут в той или иной мере сочетаться 
друг с другом. При инфицировании оперативной па- 
мяти вирус ищет свободное место в памяти и записы- 
вает туда свою копию. Затем вирус переопределяет од- 
но или несколько прерываний, необходимых ему для 
поиска заражаемых файлов, для выполнения деструк- 
тивных действий или звуковых и видеоэффектов. 

При инфицировании файла вирус может произво- 
дить ряд действий, маскирующих и ускоряющих его 
распространение. К подобным действиям можно отнес- 
ти обработку атрибута 
геаб-опіу, снятие его пе- 
ред заражением и вос- 
становление после. Мно- 
гие файловые вирусы 
считывают дату послед- 
ней модификации фай- 
ла и восстанавливают ее 
после заражения. Для 
маскировки своего рас- 
пространения некоторые 
вирусы перехватывают 
прерывание ЭОЗ, возни- 
кающее при обращении 
к защищенному от запи- 
си диску (іпі 24Н), и са- 
мостоятельно обрабаты- 
вают его. 

003 предусматривает 
единственный способ со- 
здания резидентных 
(Т5Ю модулей (помимо 
драйверов, указываемых 
в СОЫРІС.5Ѵ5) — при 
помощи функции КЕЕР 
(іпі 2 1 Н, аН = 31 или іпі 
27Ь). Многие файловые вирусы для маскировки своего 
распространения используют другой способ: обрабаты- 
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вая системные области, управляющие распределением 
памяти (МСВ), выделяют для себя свободный участок 
памяти, помечают его как занятый и переписывают 
туда свою копию. Некоторые вирусы внедряют свои 
Т5К.-КОПИИ в свободные участки памяти в таблице 
векторов прерываний, в рабочие области 005, в па- 
мять, отведенную под системные буфера. 

Загрузочные вирусы 

Загрузочные вирусы заражают загрузочный (ВооО сек- 
тор флоппи-диска и Вооі-сектор или Мазіег Вооі 
Кесоггі (МВК.) винчестера. При инфицировании диска 
вирус переносит оригинальный Вооі-сектор (или МВК.) 
в какой-либо другой сектор диска (например, в пер- 
вый свободный) и копирует себя в загрузочный сектор 
(или в МВК). Если длина вируса больше длины секто- 
ра, то .в заражаемый сектор помещается первая часть 
вируса, остальные его части размещаются в других 
секторах (например, в первых свободных). Если про- 
должение вируса размещается в первых свободных 
секторах диска, то они, как правило, помечаются как 
сбойные (точнее, сектора образуют кластер или кла- 
стеры, которые и помечаются как сбойные, так назы- 
ваемые псевдосбойные кластеры). 

СТАНДАРТНЫМ СПОСОБОМ РАЗМЕЩЕНИЯ загру- 
зочного вируса на диске далее будет называться такой 
способ, при котором продолжение вируса размещается 
в последовательных секторах диска, образующих псев- 
досбойные кластеры. 


в) переносит себя в другую область памяти (например, 
в самые старшие адреса памяти); 

г) устанавливает необходимые вектора прерываний; 

д) совершает, если они есть, дополнительные дей- 
ствия; 

е) копирует в память оригинальный Вооі-сектор и пе- 
редает на него управление. 

Действия а) — е) далее будут упоминаться как 
СТАНДАРТНЫЕ. 

В дальнейшем загрузочный вирус ведет себя так же, 
как и резидентный файловый вирус: перехватывает 
обращения операционной системы к дискам и инфи- 
цирует их, в зависимости от некоторых условий совер- 
шает деструктивные действия или вызывает звуковые 
или видеоэффекты. 

ОПИСАНИЕ ВИРУСОВ 


Ниже приводятся результаты анализа алгоритма ра- 
боты имеющихся у меня файловых и загрузочных ви- 
русов. Наиболее общие свойства вирусов представлены 
в таблицах каталога, дополнительная информация о 
каждом вирусе содержится в его описании. 

Если свойство вируса отмечено в таблице, то в опи- 
сании вируса оно может не упоминаться. Если файло- 
вый или загрузочный вирус совершают стандартные 
действия (см. выше), то описание этих действий мо- 
жет быть опущено. 


Незараженный диск 

Номер сектора : 

I — Воот-сектор или Назтег Воот Несогр 

Зараженный диск 

' — Продолжение вируса 

^ — Сохраненный Воот-сектор 
или Назтег Воот НесогО 


1 __ 


Начало вируса 


Известные мне загрузочные вирусы всегда резидент- 
ны. Они внедряются в память компьютера при загруз- 
ке с инфицированного диска. При этом системный за- 
грузчик считывает содержимое первого сектора диска, 
с которого производится загрузка, помещает считан- 
ную информацию в память и передает на нее (т.е. на 
вирус) управление. После этого начинают выполнять- 
ся инструкции вируса, который : 

а) уменьшает объем свободной памяти (слово по адре- 
су 0040:0013); 

б) считывает с диска свое продолжение (если оно 
существует); 


Каталог вирусов 

В предлагаемом каталоге для каждого 
вируса приведена информация о 
свойствах, описанных выше. Сим- 
вольное представление этих свойств 
во многом повторяет классификаци- 
онный код Н.Н. Безрукова. 

В качестве основных опознавате- 
лей вируса будет указываться его имя 
и длина. Если вирус имеет несколько 
имен, то указываться будет одно из 
них, остальные известные мне имена 
приведены в табл. 4 каталога. 

Длиной файлового вируса считает- 
ся длина тела вируса (коды+дан- 
ные+стек вируса, если он есть) без 
всяких добавок. В большинстве случаев она равна ми- 
нимальному приращению длин файлов при их зараже- 
нии. Для загрузочных вирусов в качестве длины при- 
нимается полная длина тела вируса, т.е. число зани- 
маемых вирусом секторов, умноженное на число байт 
в секторе. 

В таблицах каталога используются такие символы: 
+ — наличие свойства; 

отсутствие свойства; 

* — в описании имеется дополнительная информация; 
& — наличие различных свойств; 

V — вызывает видеоэффекты (Ѵісіео); 
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М — вызывает звуковые эффекты (Мизіс); 

Н — имеет деструктивную функцию (Наггп); 

Ег — содержит ошибку, которая может проявляться 
как деструктивная функция (Еггог); 

СИ — изменяет служебную информацию: на диске — 
имя диска, в 005 — возвращает неверную версию 
005 и т.п. (СИап^е). 

Для файловых вирусов (табл. 1): 

С — СОМ-файлы; 

.С — .СОМ-файлы (файлы с расширением “.СОМ“); 

Е — ЕХЕ-файлы; 

.Е — .ЕХЕ-файлы (файлы с расширением 44 .ЕХЕ“); 

5 — 5Ѵ5-файлы; 

0 — прочие файлы (ОіНег). 

Для загрузочных вирусов (табл. 2): 

В — Вооі-сектор винчестера; 

М — МВК. винчестера; 

Р — Вооі-сектор флоппи-дисков. 

Для файлово-загрузочных вирусов употребляется 
полный нйбор символики. 

Например, если для файлового вируса в, графе, со- 
ответствующей поражаемым объектам, указано 
“Е С&.С 44 , то это означает, что вирус поражает только 
файлы, имеющие либо формат ЕХЕ, либо формат 
СОМ и одновременно расширение имени “.СОМ 44 (т.е. 
не поражаются файлы, которые имеют формат СОМ и 
расширение имени 44 .ЕХЕ“). 

При описании свойств файловых вирусов (табл. 1) 
используются специальные знаки. 

Место внедрения в файл: 

5 — начало (зіагі); 
е — конец (епсі); 

1 — середина (іпзегі). 

Метод заражения: 

РІЫО — используя функции РіпсІРігзІ и РіпсШехІ; 

ШТ — перехватывая обращения 005 к файлам; 

ІЫРІ — используя оба способа. 

Способ внедрения в оперативную память (только 
для резидентных вирусов): 

МСВ — оперируя с МСВ; 

КЕЕР — используя прерывания 005 (іпі 21 Н 1.31 
или іпі 27Н); 

ІпіТаЫе — записывается в таблицу векторов; 

ВиІГег — записывается в дисковый буфер. 

Длина: 

Ь — длина вируса; 

$ — длина заражаемого файла увеличивается до 
значения, кратного параграфу; 

-и- — возможно повторное заражение файлов. 

Файловые вирусы 

Семейство “АтхІгасГ 4 

Семейство (в моей коллекции — 6 штук) нерези- 
дентных опасных вирусов. Общие черты: 

— заражаются все .СОМ-файлы в текущем оглавле- 
нии; 

— вирус записывает себя в начало файла; 


— возможно повторное заражение; 

— файлы большой длины могут быть уничтожены. 

Некоторые версии вируса быстро проявляются: на- 
чиная с пятого “поколения* 4 вируса, при старте зара- 
женной программы с вероятностью 1/2 на экране по- 
является сообщение: “Рго^гатт зіск еггог: Саіі сіосіог 
ог Ъиу РІХЕЬ Іог сиге сіезсгірііоп**. Одна из версий вы- 
дает на экран политический лозунг на болгарском 
языке. 

Семейство “АпІі-РахсаГ 

Семейство (5 штук) очень опасных нерезидентных 
вирусов. Заражают или портят не более 2-х файлов во 
всех каталогах на текущем диске и диске С:. При по- 
иске незараженных файлов используется рекурсивный 
обход дерева каталогов. Заражают .СОМ-, .ВАК- и 
.РА5 файлы. В случае СОМ-файла вирус записывается 
в его конец (версии вируса длин 400, 440 и 480) или 
начало (остальные версии вируса). При заражении 
.ВАК и .РА5-файлов записывается в начало файла, 
при этом старое начало не сохраняется, то есть файл 
оказывается безвозвратно потерянным. Некоторые вер- 
сии вируса переименовывают .ВАК и .РА5 файлы в 
.ЕХЕ. 

Семейство “Аргіі (“ЗИМУ 44 ) 

“Аргіі І5І СОМ 4 * 

Файловый резидентный опасный вирус. Поражает 
.СОМ-файлы (кроме СОММАЫО.СОМ) при их запуске 
на выполнение (іпі 21 Н, ах = 4В00Ю. Опасен — не 
проверяет длин файлов. Записывается в начало файла. 
При заражении: 

а) создает файл ТМР$$ТМР.СОМ; 

б) записывает в него свою копию; 

в) дописывает в него заражаемый файл; 

г) уничтожает заражаемый файл; 

д) присваивает файлу ТМР$$ТМР.СОМ имя зара- 
жаемого файла. 

При создании своей резидентной копии использует 
функцию 31 Н прерывания 21 Н (по схеме “Иерусалим- 
ского 44 вируса). 

Проявляется начиная с 1 апреля 1988 года при за- 
ражении файлов: выводит на экран текст “АРКИ, 15Т 
НА НА НА ѴОІІ НАѴЕ А ѴІКП5 44 и завешивает сис- 
тему; в последующие дни сообщает “ѴОІІ НАѴЕ А 
ѴІКІІ5 !!“. Перехватывает іпі 21 Ь. Помимо перечис- 
ленных, содержит строки “зІЖІѴ 44 (в начале заражен- 
ного файла), “СОММАЫЭ.СОМ 44 , “ТМР$$ТМР.СОМ“. 

“Аргіі І5І ЕХЕ 44 

Файловый резидентный опасный вирус. Поражает 
.ЕХЕ-файлы при их запуске на выполнение (іпі 21 Н, 
ах = 4В00Н). Опасен — не вполне корректно работает 
с длиной файла. При заражении внедряется в середи- 
ну файла между заголовком и загружаемым модулем, 
при этом вирус: 

а) создает файл ТМР$$ТМР.ЕХЕ; 
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б) считывает из заражаемого файла первые 1 ВН бай- 
тов заголовка, модифицирует в них байты, соответ- 
ствующие длине модуля, стартовым значениям С5, 
ІР, 55, 5Р, контрольной сумме файла (устанавлива- 
ется значение 1984Н); затем записывает модифици- 
рованный заголовок в файл ТМР$$ТМР.ЕХЕ; 

в) копирует из заражаемого файла в ТМР$$ТМР.ЕХЕ 
таблицу настройки адресов (ТНА), модифицируя ее 
описанным ниже способом; 

г) дописывает в файл ТМР$$ТМР.ЕХЕ копию вируса; 

д) дописывает в файл ТМР$$ТМР.ЕХЕ загружаемый 
модуль инфицируемого файла; 

е) уничтожает заражаемый файл; 

ж) присваивает ТМР$$ТМР.ЕХЕ имя заражаемого 
файла. 

Незараженный файл Зараженный файл 


ЕХЕ Меайег 


Загружаемый 

модуль 


> 



ЕХЕ Ьеасіег 


Вирус 


Загружаемый 

модуль 


Так как загружаемый модуль файла при заражении 
смещается на расстояние, равное длине вируса, то ви- 
русу приходится производить соответствующие изме- 
нения в ТНА: у каждого элемента ТНА содержимое 
байтов, соответствующих смещению сегмента, увели- 
чивается на значение, равное длине вируса в парагра- 
фах. 

При создании своей резидентной копии использует 
функцию 31 Н прерывания 21 И (по схеме “Иерусалим- 
ского 44 вируса). 

Начиная с 1 апреля 1988 года при активизации рас- 
шифровывает (ХОК РЕЮ и выводит текст “АРКІЬ 
15Т НА НА НА ѴОІІ НАѴЕ А ѴІКІІ5 44 и завешивает 
систему; в последующие дни текст не появляется, а 
система зависает приблизительно через 55 минут по- 
сле активизации. Перехватывает іпі 21 И и, в зависи- 
мости от текущего дня, может перехватывать іпі 1 СН . 
Содержит строки “5ІЖІѴ 44 и “ТМР$$ТМР.ЕХЕ“. 


Семейство “Есісііе" 


“Е<1 (1іе-65 1“ 

Инфицирует СОМ- и ЕХЕ-файлы при загрузке их в 
память для выполнения (іпі 2 1 Н, ах = 4В00Н). У зара- 
жаемого файла устанавливает значение секунд в 1РН. 
Никак не проявляется. Содержит строку “Есісііе Ііѵез 44 . 
Изменяет вектор прерывания 21 Н. 

Вирус перехватывает функции Э05 РіпсІРігзІ и 
РіпгіЫехІ РСВ (іпі 2 1 Н, аН = 1 1Н, 12Н) и “уменьшает 44 
длины зараженных файлов, т.е. вирус невозможно оп- 
ределить по изменению длин файлов (если, конечно, 
он резидентно находится в памяти). Утилиты, которые 
не используют указанные функции 005 (например, 
Ыогіоп Соттапсіег), а напрямую используют содержи- 
мое секторов, хранящих каталог, показывают правиль- 


ную длину зараженных файлов. При “уменьшении 44 
длин файлов вирус определяет их зараженность по 
значению секунд даты последней модификации (62 
секунды) и не проверяет истинных длин файлов. Если 
такое значение секунд встретится у файла небольшой 
длины (меньше 651 байт), то команда ИІК выдаст 
несколько странную длину файла — около 4 гигабайт. 

“Есісііе- 1800“ 

Очень опасный резидентный файловый вирус. 
Быстро размножается: инфицирует СОМ- и ЕХЕ-фай- 
лы при загрузке их в память для выполнения, при со- 
здании, переименовании, .открытии и закрытии файла 
(іпі 2 1 Н, ах = 4В00Н или аН = ЗСН, 5ВЬ, 56Н, ЗЭЬ, 
2ЕЮ. 

При создании своей копии в оперативной памяти 
компьютера вирус пытается занять область памяти с 
самыми старшими адресами, разрушая временную 
часть командного интерпретатора СОММАЫО.СОМ. 
По окончании работы программы командный интер- 
претатор СОММАЫО.СОМ восстанавливает свою вре- 
менную часть, при этом происходит открытие файла 
СОММАЫО.СОМ и, соответственно, его заражение. 
Таким образом, наиболее подверженным заражению 
файлом является СОММАЫО.СОМ. 

Вирус предпринимает ряд эффективных мер для то- 
го, чтобы остаться незамеченным. 

1) При старте любой программы вирус помечает про- 
граммный сегмент как последний и становится неви- 
димым для этой программы, по окончании работы 
программы вирус помечает программный сегмент как 
не последний. 

2) Аналогично вирус поступает с вектором прерывания 
21 Н при старте программы: он восстанавливает его 
первоначальное значение. 

3) Вирус не позволяет программам изменять вектор 
прерывания 2 1 Н и защищается таким образом от ре- 
зидентных антивирусов, установленных после того, 
как активизировался вирус. 

4) Вирус пытается обойти программы, следящие за 
прерыванием 1 ЗН, и установить вектор этого преры- 
вания в его первоначальное значение. 

Вирус очень опасен: периодически стирает сектор 
со случайным номером (“оплевывает 44 диск), при этом 
он может уничтожить часть информации на диске. 
Вирус анализирует 2 байта (8-й и 10-й) Вооі-сектора 
диска, с которого была запущена зараженная програм- 
ма. Вирус увеличивает на 1 значение 10-го байта и 
сохраняет его в Вооі-секторе. Если новое значение ір- 
го байта кратно 16, то вирус стирает на диске сектор 
со случайно выбранным номером, зависящим от значе- 
ния 8-го байта. 

Изменяет вектора прерываний 1 ЗН, 21 Ь, 27Н. Со- 
держит текстовые строки “Есісііе 1іѵе5...5оте>ѵЬеге іп 
Ііте 44 , “Оіапа Р.“, “ТЫз рго^гаш >ѵаз лѵгіПеп іп ІНе сііу 
о? 5оПа (С) 1988-89 Эагк Аѵеп^ег 44 . 

“ЕсІсІіе-2000 44 и “ЕсІсІіе-2 100“ 

Очень опасные резидентные файловые вирусы. 
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Быстро размножаются: инфицируют файлы при за- 
грузке их в память для выполнения, при создании, пе- 
реименовании и закрытии файла, при чтении или из- 
менении его атрибутов (іпі 21 Н, ах = 4В00Н или 
аН = ЗСН, ЗЕН, 43Ь, 56Н, 5ВН). 

Вирусы следят за тем, чтобы длины заражаемых 
файлов увеличивались ровно на 2000 (или 2100) байт 
(к ЕХЕ-файлам, помимо выравнивания на границу 
параграфа, дописывается необходимое число байт). У 
заражаемых файлов (как и при поражении вирусом 
“Ѵіеппа 44 ) устанавливается новое значение секунд да- 
ты последней модификации — 62 секунды. 

Вирус 44 Е(І<ііе-2000“ предпринимает ряд эффектив- 
ных мер для того, чтобы остаться незамеченным, мно- 
гие из них повторяют аналогичные меры вируса 
“Ебсііе-1800 44 . Маскирующую^ функцию выполняет 
длина вируса: достаточно трудно заметить приращение 
длины, кратное 1000 байтам. Введена и другая функ- 


ция защиты: вирус перехватывает функции ЭОЗ 

РіпбРігзІ и РіпсіЫехІ РСВ (іпі 21Н,аЬ = 1 1Н.12И) и 
“уі^ньшает 44 длины зараженных файлов на 2000 байт. 

Вирус “Е<і(1іе-2100 44 дополнительно к этому обраба- 
тывает функции РіпсІРігзІ и РтбЫех! А5СІ I 
(аН = 4ЕН.4РЮ; исправлена ошибка, из-за которой ко- 
манда ОІК сообщала, что длина файла около 4 гига- 
байт (см. описание вируса 44 Е<ісііе-651 44 ). Вирус непо- 
нятным мне образом манипулирует с секторами вин- 
честера — видимо, пытается либо активизировать, ли- 
бо вылечить неизвестный мне загрузочный вирус. 

Вирусы “ЕскІіе-2000 44 и 44 Ес1(Гіе-2100 44 очень опасны: 
аналогично вирусу “Есісііе- 1 800“ стирают сектора со 
случайными номерами. При этом вирусы обращаются 
напрямую к драйверу, обслуживающему диск, и обхо- 
дят многие резидентные блокировщики. 

Изменяют іпі 1 ЗН, іпі 21 И, іпі 27Н. Содержат тек- 
стовые строки 44 Диана П.“, “(с) 1989 Ьу Ѵеззеііп 
ВопІсНеѵ 44 ; вирус “Ебсііе- 
2000“ — “Хору те — I шапі Іо 
Ігалѵеі 44 , вирус “ЕбсІіе-2100 44 — 
“Еббіе ііѵез 44 . Если в теле за- 
пускаемой программы содер- 
жится строка “Ѵеззеііп 
ВопІсНеѵ 44 (Весселин Бончев — 
автор известных • болгарских 
антивирусов), то вирус зацик- 
ливается и система зависает. 


Семейство “Са$сас1е“ 


Мне известны два предста- 
вителя семейства: “Сазсабе- 

1701“ и “СазсасІе-1704 44 . Их 
тела, за исключением начала 
(32 байта), зашифрованы. В 
качестве ключа используется 
длина зараженного файла, по- 
этому два “штамма 44 одного 
вируса в большинстве случаев 
будут совпадать только на пер- 
вых 32 байтах. 

При выполнении заражен- 
ной программы управление с 
помощью команды ІМР пере- 
дается на начало вируса. Пер- 
выми командами вирус опреде- 
ляет длину исходного файла и 
расшифровывает свое тело. 

При создании своей рези- 
дентной копии вирус: 

а) копирует свое тело в стар- 
шие адреса памяти; 

б) перемещает в старшие адре- 
са тело основной программы; 

в) перемещает свое тело в ос- 
вободившееся над телом ос- 
новной программы простра- 
нство; 


Таблица 3. Названия вирусов. 


СазсаРе 

Раіііпд ІеТТегз, І_е*ТегРа 1 1 , Сгуіпд зсгееп, 
РазН, Огоррег, Листопад, Раіііпд Іеагз, 
НегрізТ, Ац*итп , 1704/СазсаОе , Віас^аск 

ѴАС8ІНА-ЫЫ 

Уапкее-МЫ. 

ТР-пп , где пп - десятичное представление 
числа NN 

ѴАСЗІИА-М 

Ѵасзіпа, Ѵасз, Ѵасзіпа зоилО, $іпа 

Уэикее-М 

Ооосі 1 е , Уап кее Ооосі 1 е 

Уапкее-2С 

Ріѵе О’сіоск Мизіс, ІЬгіз, Мизіс Ріауег, N6*/*/, 
ОитЬо Вгаѵ/Іег 

Ѵіеппа-648 

ТітеЬотр, РеРооТег, ЯезеТ , 008-62 , ТітезТатр, 
Резі:агТ, ѴНР-648, Ргіег, бузует геЬоот , ІМЕ8С0 

Ѵіеппа-534 

Тоо*Н1езз, МісгозоРТ 1988, МісгозоРТТугідМ: 
Нісго88 , Ѵіеппа 

Ѵіеппа-757 

Кузьмич 

АтзТгаО 

Сапсег, IV, Атз 

ЕсШе-1800 

Оагк Аѵепдег, 8оРіа, Ругатісіез, Ріала , йаѵ 
Есісііе 

ЕбсІіе-2000 

Ѵ2000, ВсН, ВопТсНеѵ, Диана П. 

Оегиза Іет 

Віаск Ноіе, Віаск РгіОау, Ізгаеіі, НеЬгеѵ/, 
Тіте, Оеги 

Зипйау 

9-8ип0ау 

Уап8ІіОгІ-1961 

РаТНег-1961 , Ооосі 1е2 

4096 

4К , 100 Уеагз, РгосЮ, Нісііпд, СепТигу 

Аргіі І5Т 

8игіѵ, Аргіі 

Ріпд-Ропд 

Ваіі, ІТаІіап Ріпд-Ропд ѵег.В, Воипсіпд Ва 1 1 
Воипсіпд Рот , Яіпд, Ѵега Сгиг 

Вгаіп/АзНаг 

РакізТапі Вгаіп/АзНаг 

Эізк Кіііег 

Кіііег, Одге 

8*опе 

N6* 2еа1апй, Магідиапа 

Реп 2ик 

ЭеагсН, Ѵепегиеіап 
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г) устанавливает іпі 1СН, іп! 21 Н и іп! 28Н на свою 
копию. 



1 . 


1 . 




Программа 

Программа 

Свободная 

память 


— > 

Вирус 

Программа 

Программа 

Вирус 

Вирус 


(копия) 

Вирус 

Вирус 






Вирус заражает только СОМ-файлы при загрузке их 
в память для выполнения (іп! 21Н, ах = 4В00Н). 
Инфицирование происходит стандартным способом. 


Наиболее распространенные версии этих вирусов 
не производят повторного заражения файлов. 

Изменяют вектора прерываний 
1СН, 21 Н и 28Н. Вызывают характер- 
ный видеоэффект: осыпание букв на 
экране. Не имеют деструктивных 
функций. 


Заранее благодарю всех, кто приш- 
лет свои замечания, предложения или 
сообщит об обнаруженных в тексте 
неточностях. 

“ Доктор “ Е. Касперский 
Москва , 8 января 1991 г. 


Ш МАЛОЕ ПРЕДПРИЯТИЕ 

ІІ“ИНФОРМ АТИКА” : 1| :: 

Учредитель - институт проблем 
информатики Академии Наук СССР 

МПРОЛОГ 

язык модульного логического программирования 

■ идеальный язык для создания экспертных систем 

■ описание прикладной задачи в терминах объектов и отношений между ними 
■ большой набор встроенных предикатов 
■ трехмерная машинная графика 

■ интерфейс с традиционными языками программирования 
■ совместимость программ для различных типов компьютеров 
■ наличие компилятора 
■ литература: 

Иванова Г.С., Тихонов Ю.В. “Введение в язык МПРОЛОГ”, 

М., Изд-во МГТУ, 1990 - 152 с. 

Калиниченко Л.А., Степанов А.И., Тихонов Ю.В. “Система МПРОЛОГ для автоматизации обработки 
знаний на ЭВМ”, М., МЦНТИ, 1989 - 112 с. 

Адрес: 117900, Москва ГСП-1, В-334, ул.Вавилова 30/6, ИПИ АН СССР, 

МП “Информатика”. 

Телефон: (095)362-46-54. Факс: (095)310-70-50. Телекс: 411853 ШРО 811 


4 Зак. 2260 
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новости 


Ассоциация 

8оК\ѵаге РиЫізЬегз Аззосіаііоп 
присудила свои ежегодные дипломы 

Диплом за выдающуюся программу (Ехсеііепсе іп 
ЗоІНѵаге Ашагсі) получила графическая многозадачная сре- 
да Сео>Ѵогкз ЕпзетЫе под >Ѵіпсіо>ѵ8 и 03/2. Программа 
победила в четырех категориях: лучшее использование 
компьютера, лучшая пользовательская программа, лучшая 
программа для повышения персональной продуктивности и 
диплом критиков за лучшую пользовательскую программу. 

МісгозоП ЛѴіпсіоѵѵз 3.0 получили 2 диплома — лучшая 
новая программа для бизнеса и диплом критиков в этой 
же категории. 

ЗітЕагіН (фирма Махіз) и АзНІаг Ѵеіішп (фирма АзНІаг) 
также получили по два диплома. 

Члены Ассоциации выбирали из 115 продуктов, пред- 
ставленных 63 компаниями, тогда как дипломы критиков 
присуждались по результатам голосования представителей 
прессы без ограничений по номенклатуре программ. 

Стив Возняк, сооснователь фирмы Арріе, получил дип- 
лом за все свои достижения в компьютерной области 
(ІіГеІіте асНіеѵетеп! а\ѵагсі) . 

Ниже следует полный список врученных дипломов. 

1. Дипломы делового программного обеспечения: 

Лучший новый программный продукт для бизнеса (Вез! 

№\ѵ Визіпезз ЗоГНѵаге Ргосіисі): МісгозоІ! ХѴіпсіошз 3.0 
(фирма МісгозоГр. 

Лучшая прикладная программа для бизнеса (графичес- 
кой или дисплейной ориентации) (Вез! Визіпезз 

Арріісаііоп: СгарЫс ог Оізріау Огіепіаііоп): аІІСЬЕАК 
(фирма СЬЕАК ЗоГнѵаге). 

Лучшая прикладная программа для бизнеса (цифровой 
или информационной ориентации) (Вез! Визіпезз 

Арріісаііоп: N 0016110 ог Эаіа Огіепіаііоп) : (}иа11го Рго 2 
(Вогіапсі Іпіегпаііопаі). 

Лучшая прикладная программа для бизнеса (текстовой 
ориентации) (Вез! Визіпезз Арріісаііоп: \Ѵогс1 ог Тех! 
Огіепіаііоп): Аті Рго (фирма Ьоіиз Оеѵеіортепі). 

Лучшее средство для программирования, (Вез! 
Рго^гаштіп^ ТооІ): ТигЬо С + + РгоГеззіопаІ (Вогіапсі 
Іпіегпаііопаі). 

Лучшая утилита (Везі Шіііу Рго^гат): ТНе Коііоп 
Шіііііез 5.0 (фирма Зутапіес). 

Лучшая программа для вертикального рынка (Вез! 
ѴеПісаІ Магкеі Арріісаііоп): АзНІаг Ѵеііит (фирма АзНІаг). 

2. Дипломы для пользовательского программного 
обеспечения: 

Лучшая . потребительская программа (Вез! Сопзштіег 
Рго^гаш): Сео\Ѵогкз ЕпзетЫе(ТМ) (Сео\Ѵогкз). 

Лучшая активная программа (Везі Асііоп/Агсасіе 
Рго^гаш): Расёз...Тгіз III (Зресігшп НоІоВуІе). 

Лучшая программа-приключенческая игра (Вез! Рапіазу 
Коіе Ріауіп^/Асіѵепіиге Рго^гаш): Кіп^'з (}ие8і V (фирма 
Зіегга Оп-Ііпе). 


Лучшее средство для повышения персональной продук- 
тивности (Вез! Регзопаі Ргосіисііѵііу/Сгеаііѵііу Рго^гат): 
Сео\Ѵогкз ЕпзетЫе(ТМ) (Сео\Ѵогкз). 

Лучшая имитационная программа (Вез! Зітиіаііоп 
Рго^гаш): ЗітЕагіН (Махіз). 

Лучшая спортивная программа (Вез! Зрогіз Рго^гат): 
ЬШКЗ (Ассезз ЗоІНѵаге). 

Лучшая стратегическая программа: (Вез! Зігаіе^у 

Рго^гат): ЗМ Меіег'з Каіігоасі Тусооп (фирма МісгоРгозе 
ЗоІНѵаге) . 

3. Дипломы программам для образования : 

Лучшая программа для обучения (Вез! Есіисаііоп 
Рго^гаш): Сотріоп'з МиІііМесііа Епсусіоресііа (зіапсі-аіопе 
ѵегзіоп) (фирма Вгііаппіса ЗоІНѵаге). 

Лучшая программа для начального обучения (Вез! Еагіу 
Есіисаііоп Рго^гат): Міхесі ІІр МоіНег Соозе (МиШтесІіа) 
(Зіегга Оп-Ііпе). 

Лучшая программа для начальной школы (Вез! 
Еіетепіагу Есіисаііоп Рго^гат): КитЪегМаге Эесішаіз & 
Ргасііопз (Сгеа! >Ѵаѵе ЗоГішаге) и Зирег Зоіѵегз 
ОиІпитЬегесІ! (ТНе Ьеагпіп^ Сотрапу). 

Лучшая программа для домашнего обучения (Вез! Ноте 
Ьеатіпя Рго^гат): Эеіихе Есііііоп оі \ѴНеге іп іНе ЛѴогІсі із 
Сагтеп ЗапсКедо (фирма ВгосІегЬипсІ ЗоГНѵаге). 

Лучшая программа для повышения продуктивности 
школьного обучения (Вез! ЗсНооІ Ргосіисііѵііу/Сгеаііѵііу 
Рго^гат): ТНе СНіІёгеп'з >Ѵгіііп8 апсі РиЫізНіп^ Сепіег (ІВМ 
пеішогкесі ѵегзіоп) (ТНе Ьеатіп^ Сотрапу). 

Лучшая программа для средней школы (Вез! Зесопсіагу 
Есіисаііоп Рго^гат): ЗітЕапН (Махіз). 

Лучшая программа для удовлетворения специальных 
запросов (Вез! ЗресіаІ №есІ8 Рго^гат): ТНе Зепіепсе Мазіег: 
Ьеѵеі 1 (фирма Ьаигеаіе Ьеатіпя Зузіетз). 

4. Дипломы всем программам: 

Лучшее новое использование компьютера (Вез! ІІзе 
оГ А Сотриіег): Сео^Ѵогкз ЕпзетЫе(ТМ) (Сео>Ѵогкз). 

Лучший пользовательский интерфейс у новой програм- 
мы (Вез! Іізег Іпіегіасе іп А №ѵѵ Рго^гат): АзНІаг Ѵеііит 
(фирма АзНІаг). 

5. Дипломы критиков: 

Лучшая пользовательская программа (Вез! Сопзшпег 
Рго^гат): Сео>Ѵогкз ЕпзетЫе (Сео\Ѵогкз). 

Лучшая деловая программа (Вез! Визіпезз Рго^гат): 
МісгозоП \Ѵіпс1о\ѵ8 3.0 (фирма МісгозоГр. 

Лучшая учебная программа (Вез! Есіисаііоп Рго^гат): 
Сотріоп'з Миііітесііа Епсусіоресііа (Вгііаппіса ЗоГНѵаге). 

6. И наконец, дипломы компьютерным журналистам: 

Лучшему аналитику: КеііН РеггеІІ, ОММ Ма^агіпе. 

Лучшие выпуски новостей: МісНаеІ Ко^егз, №\ѵзшеек. 

Лучшие обзоры программ: .ІоНппу \Ѵі1зоп, Сотриіег 

Сатт^ \ѴогІс1. 

1 ЧепзЬуІез Иекз Ыеікогк, МагсН 15, 1991. 

Мен5ЬуІе$ Ыеп5 ЫеЬѵогк, МагсН 22, 1991. 
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.Язык С+ + появился как расширение 
языка Си, предназначенное для 
поддержки объект но-ориент иро ванного 
программирования. Интерес к нему 
постоянно растет, но для того, чтобы 
в полной мере использовать его 
возможности, необходимы специальные 
знания в этой области. В противном 
случае программирование на нем 
сводится к модификации 
программирования на языке Си. Ниже 
дается краткий обзор специфических 
языковых средств С+ + и 
иллюстрируется их применение. 


Язык С++ 

и объектно-ориентированное 
программирование 


Объектно-ориентированное 

программирование 

Объектно-ориентированное программирование поя- 
вилось в результате развития методов структурного 
программирования и методов программирования с ис- 
пользованием абстракции данных. 

В структурном программировании для разбиения 
системы на составляющие элементы применяется 
функциональная декомпозиция. Этот процесс обычно 
осуществляется “сверху-вниз", в результате чего дета- 
лизируется реализация функций системы. Само разби- 
ение строится и оценивается на основе использования 
мер модульности — связности и прочности модулей. Та- 
кой метод слабо учитывает влияние обрабатываемых 
структур данных на архитектуру программы. 

В подходе, основанном на использовании абстра- 
кции данных, главное внимание уделяется выбору 
представления данных, наиболее подходящего для реа- 
лизации решаемой задачи. На основе выбора осущест- 
вляется модульная декомпозиция программ. Широко 
используется понятие типа и строится иерархия типов 
на базе детализации представления данных на различ- 
ных уровнях декомпозиции. При таком методе сущест- 
вует разрыв между структурами данных и функциями 
для работы с ними. При использовании объектно-ори- 


ентированного программирования этот разрыв уничто- 
жается. Центральным элементом в данном случае яв- 
ляется объект, представляющий собой модель некото- 
рого элемента реального мира и содержащий в себе 
как данные, так и операции над ними. 

Для построения объектов используются абстрактные 
типы данных и скрытие информации. Большое внима- 
ние уделяется взаимодействию между объектами. 

Объекты одного типа объединяются в классы, кото- 
рые представляют собой основные “строительные бло- 
ки" разрабатываемых программ. В классах интегриру- 
ются как определения данных, так и определения 
функций, выполняемых над данными. 

Для успешного применения объектно-ориентирован- 
ного метода к разработке программ необходимо нали- 
чие подходящего языка программирования. В настоя- 
щее время такими языками являются: ЗілаНТаІк, 

ТигЬо РазсаІ ѵ.6.0, С++ и др. 

Дадим краткий обзор элементов языка С++, обеспе- 
чивающих объектно-ориентированное программирова- 
ние. 

Классы и их структура 

Класс является основным элементом языка С++, 
обеспечивающим объектно-ориентированное програм- 
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мирование. Он представляет собой расширение струк- 
тур языка Си. В классах помимо определений данных 
допускаются определения выполняемых над ними 
функций. Кроме того» в них имеются средства управ- 
ления доступом к данным» позволяющие организовы- 
вать взаимодействие различных классов друг с другом 
и классов с обычными функциями. Функции» входя- 
щие в класс» часто называются методами. 

Определение класса иллюстрирует следующий при- 
мер: 

// іаггау.Н 
с!а$$ аггау 
{ 

іпі тахііет$; //максимальное число элементов 
іп! сііет$; //число элементов» размещенных в массиве 
іпі *ііет$; //указатель на массив 
риЫіс: 

//конструктор 
аггау (іпі пИетз); 

//деконструктор 
-аггау О; 

//занесение элемента в массив 
іпі риШетОпІ Нет); 

//получение элемента из массива 
іш &еіі1ет(іпі іпсі, іпі & Пет); 

//получение фактического числа элементов в массиве 
іпі соипІ({геіигп сііет$;}); 

}; 

В определении даны объявления внутренних пере- 
менных класса (переменные состояния), а также про- 
тотипы методов, обеспечивающих работу с данными. 

Приведенный класс предназначен для создания це- 
лых массивов заданной длины и для размещения в них 
целых значений. Назначение переменных пояснено 
соответствующими комментариями. 

Класс іаггау содержит в себе пять методов. Прото- 
типы четырех из них даны в файле іггау.Н, а для пя- 
того метода дана полная реализация. 

Сами исходные тексты методов класса іаггау приве- 
дены ниже: 

// іаггау .сор 
#іпс1ис1е “іаггау.Н" 

//конструктор 
іаггау: :іаггау (іпі пііетз) 

{ 

Ист$ = пе>ѵ іпІ[пііет$]; 
тахііетз = пНет$; 
сИетз = 0; 

} 

//деструктор 
іаггау ::-іаггау О 
{ 

сіеіеіе ііетз; 

} 

//занесение элемента в массив 
іпі іаггау ::риіа (іпі Нет) 

{ 

И (сііетх < тахі1ет$){ 


ііет$[сііет$] = Нет; 
сііетх + + ; 
геіит 0; 

> 

еіве 

геіит -1; 

) 

//получение элемента из массива 
іпі Іаггау::^еіа(іпі іпсі, іпі & Нет) 

( 

іГ <іп4 > = 0 && іпсі < сііетв){ 

Нет = Ііет8 [іпсі] ; 
геіит 0; 

) 

е!$е 

геіит -1; 

} 

Среди методов особое место занимают такие два 
метода, как конструктор и деструктор. С помощью ко- 
нструктора, в данном случае, создается массив целых 
значений заданной длины. В нем фиксируется длина 
массива и устанавливается счетчик занятых элемен- 
тов, а также производится распределение памяти под 
массив. Последняя операция выполняется введенным в 
язык С++ оператором пеіѵ. Он проще, чем функция 
таііос, так как при его применении не требуется зада- 
вать размер выделяемой памяти в байтах и преобразо- 
вывать полученный указатель к конкретному типу. 

Второй специальный метод — деструктор. С* его по- 
мощью уничтожается созданный конструктором объ- 
ект. Для уничтожения динамически созданных объек- 
тов в языке С++ используется оператор беіеіе, выпол- 
няющий роль функции Ігее языка Си. 

Методы риіііет и зеіііет обеспечивают контролиру- 
емое обращение к элементам массива. В первом мето- 
де отслеживается возможность размещения нового эле- 
мента в массиве. Во втором — правильность задания 
индекса получаемого из массива элемента. 

Метод соипі позволяет получить число включенных 
в массив элементов. Он реализован прямо в исходном 
тексте заголовочного файла іаггау.Н. 

Отметим, что при определении методов за предела- 
ми текста класса используется операция напри- 
мер: 

іпі іаггау: :риіііет О 

Эта операция говорит о том, что областью действия 
метода риіИет является класс иаггау. 

Коснемся теперь использования определенного нами 
класса. Можно привести следующий пример 

#іпс!ис1е “аггау.Н" 

#Іпс!ис!е <іо$ігеат.Н> 

#1пс1ис1е <$ісНіЬ.Н> 

#іпс!исіе <ііте.Н> 

іпі таіпО 

< 

аггау т(10); 
іпі і,],к: 

Іпі п; 
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гашкнпігеО; 

Гог (і = 1;і < = 5;і+ ♦ ){ 
т.риіІіеш(гапсЮ); 

} 

п - т.соипК); 

Гог (і = 0;і < = п;і ♦ + ){ 
т.деШетО,]); 
сои* < < і < <“\п“; 

} 

} 

В этом примере создается объект т , принадлежа- 
щий классу іаггау. Далее в массив т вводится пять це- 
лых чисел, полученных путем обращения к датчику 
случайных чисел. Эти числа вводятся в выходной по- 
ток соиі, которому соответствует дисплей. 

В данном примере мы сталкиваемся с важнейшим 
понятием объект. Объектом является переменная ш, 
объявленная как принадлежащая классу іаггау. Объ- 
ект — это конкретный экземпляр массива целых чи- 
сел. 

Действия с объектами осуществляются с помощью 
методов, обращение к которым задается составными 
именами, например, 

т.риШстО; 

ИЛИ 

т.^еіііетО; 

Отметим, что в объявлении 

іаггау т<10); 

также происходит вызов конструктора, в котором со- 
бственно и выполняются действия по созданию масси- 
ва. 

Есть другая возможность создания объекта с помо- 
щью оператора пе^ѵ. Например, в следующем фраг- 
менте программы 

іаггау *а; 

іаггау *Ъ; 

іт пі = 10; 

іт п2 = 20; 

а = пеѵѵ іаггау(пі); 

Ь = пеѵѵ іаггау (п2); 

(Іеіеіе а; 
сіеіеіе Ь; 

динамически создаются два массива а и Ь, размернос- 
тью 10 и 20 соответственно. 

Связь класса с внешней средой 

В объектно-ориентированном программировании 
широко используются абстрактные типы данных и 
скрытие информации. Следовательно, проблема взаи- 
модействия классов со средой, в которой они исполь- 
зуются, приобретает первостепенное значение. 

Решается эта проблема путем управления доступом 
к элементам классов с помощью использования в оп- 
ределениях классов ключевых слов ргіѵаіе, риЫіс и 
ргоіесіеб. 

Описатель ргіѵаіе говорит о том, что следующие за 
ним составляющие элементы класса скрыты внутри 


него и недоступны непосредственно во внешней среде. 
Обращение к ним допускается только внутри класса с 
помощью его методов. 

Описатель риЫіс говорит о том, что следующие за 
ним элементы класса доступны во внешней среде. 
Обычно риЫіс указывается перед методами класса. 

Отметим, что элементы класса не могут иметь опи- 
сателей типа памяти аиіотаііс, ехіегп. Они могут 
иметь дополнительно только описатель зіаііс. Элемент 
класса с описателем зіаііс будет общим для всех объ- 
ектов данного класса. 

Помимо риЫіс и ргіѵаіе в классах можно использо- 
вать описатель Ггіепсі, с помощью которого объявляют- 
ся “дружественные 44 ему функции и целые классы. Ес- 
ли в классе объявлен прототип функции с описателем 
Ггіепсі, не принадлежащий ему, то эта функция полу- 
чает. право доступа к внутренним элементам класса, 
например 

с!а$$ іуре { 
ргіѵаіе: 
іпі ргтп; 

риЫіс: 

Ггіепсі ѵоіеі Гіуре (іуре х, Іпі у); 

); 

ѵоіеі Гіуре (іуре х, іпі у); 

{ 

х.ргш = у; 

) 

В данном примере в “дружественной 44 классу а 
функции Гіуре осуществляется доступ к внутренней 
переменной ргт объекта х, принадлежащего к классу 
іуре. 

Отношения между классами 

Одной из важнейших черт объектно-ориентирован- 
ного программирования является наличие механизма 
наследования свойств одного класса другими классами. 
Он позволяет строить новые классы на базе ранее со- 
зданных и этим самым способствует повторной ис- 
пользуемости результатов процесса программирования. 

Программа может включать в себя набор базовых 
классов, которые не связаны ни с какими другими. На 
основе базовых классов строятся производные классы, 
которые наследуют от базовых классов их структуры 
данных и методы. Таким образом, производные классы 
становятся расширением базовых, при этом они не 
включают в себя детали реализации базовых классов. 

Рассмотрим пример, иллюстрирующий механизм 
взаимодействия между базовым и производными клас- 
сами: 

// Ьазеагг.Ь 

сіа$8 Ьа$еаггау 

{ 

ргоіесіесі: 

іпі тахііет$; // максимальное число элементов 
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іпі сііетз; //число размещенных элементов 

риЫіс: 

//конструктор 

ЪазеаггауОпі пііетз) {тахііетз = пііетз; сіпетз = 0;}; 

}; 

// іаггау. Н 

сіазз іаггауіриЫіс Ъазеаггау 

< 

ргіѵаіе: 

іпі *ііетз; 

риЫіс: 

//конструктор 
іаггау (іпі пііетз); 

//деструктор 
-іагтау О; 

//занесение элемента в массив 
іпі риіііет(іпі Нет); 

//получение элемента из массива 
іпі деіііетОпі іпсі.іпі & ііет); 

//получение числа элементов, размещенных в массиве 
іпі соипі ({геіигп сііетз;}); 

}; 

Исходный текст методов класса іаггау приведен ни- 
же 

// іаггау.срр 

#іпсіи(1е “Ъазеагг.Н 44 
#іпс1исіе “іаггау.Н 44 

//конструктор 

іаггау ::іаггау (іпі пііетз): Ъазеаггау (пііетз) 

{ 

ііетз = пе>ѵ іпі [пііетз]; 

} 

//деструктор 
іаггау: :-іаггау О 
{ 

сіеіеіе ііетз; 

) 

//занесение элемента в массив 
іпі іаггау ::риШет (іпі ііет) 

{ 

іГ (сііетз < тахііетз) { 
ііетз [сііетз] = ііет; 
сііетз + + ; 
геіигп 0; 

} 

еізе 

геіигп -1; 

} 

//получение элемента из массива 
іпі іаггау ::^еіііет (іпі іпсі.іпі & ііет) 

{ 

іГ (іпсі > = 0 && іп(і < сііетз) { 


ііет = ііетз [іпсі]; 
геіигп 0; 

} 

еізе 

геіигп -1; 

) 

//получение числа элементов, размещенных в массиве 
іпі іаггау::соипі() {геіигп сііетз;}; 

В новой версии реализации массива выделен базо- 
вый класс Ъазеаггау, в котором определены общие для 
массивов составляющие, независимо от типов элемен- 
тов. В производном классе определен конкретный тип 
массива. В нашем случае тип массива іпі, хотя можно 
определить тип массива как Иоаі, как зігисі и т.п. 

Класс іаггау наследует от класса Ъазеаггау кон- 
структор. При создании объекта типа іаггау в кон- 
структоре іаггау вызывается конструктор Ъазеаггау. 

С помощью механизма наследования осуществляет- 
ся скрытие информации. Следует обратить внимание 
на то, что в базовом классе появился новый описатель 
управления доступом — ргоіесіесі. Его наличие гово- 
рит о том, что следующие за ним переменные будут 
доступны в производном и недоступны в классах и 
функциях, не принадлежащим к этим классам. 

Улучшение изобразительных свойств языка 

В языке С++ реализован ряд новшеств, позволяю- 
щих во многих случаях улучшить читаемость про- 
грамм и упростить их написание. 

Прежде всего отметим расширение способов переда- 
чи параметров в функции. Возможна передача пара- 
метров не только по значению, но и по имени. Рас- 
смотрим такой пример 

ѵоісі зит (іпі *таз, іпі п, іпі &з); 
іпі таіп () 

{ 

іпі з; 

іпі таз(5] = {1,2, 3,4,5}; 

зит (тиз, 5, з); 
ргіпіГ ( м %а\п м , з); 

} 

ѵоісі зит (іпі *таз, іпі п, іпі &з); 

{ 

іпі і; 

8 = 0; 

Гог (і = 0; і,п; і + + ) 

3 = 3 + таз(і); 
геіигп; 

} 

Параметр з в функции зит и в объявлении ее про- 
тотипа объявлен как передаваемый по имени. Это из- 
бавляет от необходимости работы с указателями. 

Другим ценным свойством языка С++ является воз- 
можность замещения операции и функций. Следую- 
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Имеется класс записей: 

с1а$$ гес 

{ 

ргіѵаіе: 
іпі а; 
іпі Ь; 

сЬаг 8іг [10] ; 
риЫіс: 

гес (іпі хі, іпі х2) 

< 

а = хі; ■ 

Ь = х2; 

*$1г = 0; 

) 

ѵоісі асісі (гес & рі, гес р2) 

{ 

рі.а = рі.а + р2.а; 
рІ.Ь = рІ.Ь + р2.Ь; 

} 

}; 


Если в программе объявлены два объекта 
гес г1 (1,2); 
гес р2(3,4); 

то можно выполнить суммирование гі и г2 следующим 
образом: 

асісі (гі, г2); 

Можно определить метод сложения двух объектов 
типа гес следующим образом: 


гес орегаіог + (гес & рі, гес р2) 

{ 

рі.а = рі.а + р2.а; 
рІ.Ь = рІ.Ь + р2.Ь; 


геШгп; 

} 

Теперь объекты класса гес складываются следующим 
образом: 

рі - рі + р2; 

Выше кратко рассмотрены некоторые возможности 
языка С++, используемые в объектно-ориентированном 
программировании. Их применение в полной мере 
требует изучения как конструкций языка, так и мето- 
дов проектирования и реализации объектно-ориенти- 
рованных программ. 

Этой проблеме посвящена книга “Объектно-ориен- 
тированная разработка программ на языке С++“, изда- 
ние которой планируется в текущем году. В ней будут 
детально показаны возможности системы ТигЬо С++ 
для реализации программ, связанных с обработкой 
экономической информации. В качестве примеров рас- 
сматриваются классы, обеспечивающие работу с кла- 
виатурой, дисплеем ПЭВМ типа ІВМ РС, классы для 
работы в оперативной памяти (строки переменной 
длины, списки, очереди), классы для выполнения диа- 
логового ввода-вывода, классы для управления про- 
граммами, классы для обеспечения связи с файловой 
системой М5 Э05 и др. 

Пример взаимодействия классов строится на реали- 
зации простого редактора текстов. 

Заказы на книгу Черноусова Е.А. “Объектно-ориен- 
тированная разработка программ на языке С++“ про- 
сим направлять по адресу: 103062, Москва, а/я 86 

Е. Черноусое 


НАШИ ПРОГРАММНЫЕ ПРОДУКТЫ - КЛЮЧ К УСПЕШНОМУ РЕШЕНИЮ ВАШИХ ЗАДАЧ! 

Центр “ИНТЕРФЕЙС” предлагает пользователям ІВМ РС-совместимых ПЭВМ: 

1. НОВАЯ ГРАФИЧЕСКАЯ БИБЛИОТЕКА ДЛЯ ФОРТРАНА-77 РОКСКАР. 

Компактная и мощный набор графических функций, окна, графики, гистограммы, оси координат, перемещение и копирование 
сегментов изображений, курсоры, работа с текстом, ввод символов, интерактивная графика, ЕСА - монитор. 

Стомость - 650 рублей. * 

2. ПАКЕТ ПРОГРАММ РАСШИРЕННОЙ ГРАФИКИ НА СИ. 

Поставляемый в исходных текстах пакет поддерживает работу со спрайтами и дополнительным буфером видеодисплея, движущиеся 
окна, математическую систему координат, ввод осей, графиков, гистограмм и множество других уникальных возможностей. ССА- и 
ЕСА- мониторы, Турбо- и Микрософт- Си. Стоимость 395 рублей. 

3. ДИАЛОГОВАЯ СИСТЕМА МОДЕЛИРОВАНИЯ И ЦИФРОВОЙ ОБРАБОТКИ СИГНАЛОВ. 

Система І5Р (Іпіегасііѵе 5іп$а) Ргосе$$іп^) является идеальным инструментальным средством для автоматизации научных исследо- 
ваний, анализа экспериментальных данных, характеризуется простотой использования графических средств (ССА и ЕСА), развитым 
диалогом, наличием команд статистического анализа, спектральных преобразований (БПФ и др.), вычисления свертки и корре- 
ляционных функций, фильтрации и восстановления сигналов и др. Стоимость системы 750 рублей, в исходных текстах - 2500 
рублей, подмножество системы в виде библиотеки программ на Си в исходных текстах - 1500 рублей. 

По запросам вышлем условия поставки, описание, демо-дискету. Возможна поставка почтой по гарантийным письмам. Для частных 
лиц скидка 50%. 

142432, Черноголовка, ННЦ АН СССР, а/я 33, “Интерфейс**, Гайфуллин Б.Н. 
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ВВЕДЕНИЕ В М3 \Ѵтсіоѵѵ 5 


Введение в 

М5 Ѵ/іпс1оѵѵ5 


Характерные примеры работы 

Итак, мы разобрали почти все фундаментальные поня- 
тия М3 >Ѵіпс1о^ѵз. Пройдено больше половины пути. 
Чтобы подвести некоторый итог, давайте рассмотрим 
вполне конкретный пример на языке иллюстраций. 
Этот пример должен закрепить ваши знания визуаль- 
но. 

Рассмотрим сначала конкретный пример работы с 
файлом. Работа с файлом осуществляется посредством 
Меню Файла (Рііе), входящего практически в любую 
программу для М3 Шіпсіо^ѵз. 



Сначала рассмотрим подробно меню Рііе (Файл): 
Команда Действие 

Ые>ѵ (новый) Удаляются все существующие 

данные, удаляется имя файла из 
прямоугольника заголовка. 

Программа стартует с самого 
начала. Если команда может 
испортить существующие данные, 
выдается соответствующая 
панель сообщения. 

Ореп... С помощью модальной панели 

(открыть) диалога пользователь указывает 

имя файла и затем открывает 
этот файл в качестве текущего. 

Заѵе Запоминает существующие данные 

(запомнить) в текущем файле. Если файл не 

указан, т.е. данные вводились 
после команды Ые\ѵ, то 
автоматически генерируется 
команда Заѵе Аз... 

Главы из книги А. Н. Никольского и В.Ю. Назарова “ Введе- 
ние в М8 ]Ѵігиіою'', выпускаемой издательством " Финансы 
и статистика н в 1991 г. Продолжение. Начало в № 4. 


Заѵе Аз... С помощью модальной панели 

(запомнить в) диалога пользователь указывает 

имя файла, куда будут записы- 
ваться данные. Далее произво- 
дится запись файла на диск. 

Теперь промоделируем некоторые часто встречаю- 
щиеся ситуации при работе с меню Файл. 

1. Выбирается команда Ые>ѵ, но на экране имеются 
вводимые ранее данные, связанные с файлом А.ТХТ. 
Данные надо запомнить. 



“Запомнить ли изменения в файле А.ТХТ 7 
Ответ: “Да" 


АН, N -> Епіег 

2. Теперь рассмотрим предыдущий пример, но дан- 
ные запоминать не будем. 



“Запомнитъ ли изменения в файле А.ТХТ 7 
Ответ:“Нет“ 


3. Рассмотрим пример, когда после выбора команды 
Ыедѵ введены данные и их требуется запомнить в фай- 
ле В.ТХТ. 
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4. Определенного навыка требует работа с полями 
списка. Активизируем, например, команду Ореп ... и 
выберем из списка требуемый файл. 



Поле редактировании 
Текущая директория 


Файлы 


Диски 


Директории 


АВС.ТХТ 

ЯЕАОМЕ.ТХТ 

М 

т 

[-С-] 

и 

[ООСЦМЕМ] 

[ТЕМР] 


[ Ореп 3 I 


[ Сапс «Ч : 



обычным щелчком и активизацией ко- 
мандной кнопки Ореп. Аналогично будет 
изменен список, если произвести двой- 
ной щелчок над именем поддиректории. 
В список будут включены все файлы 
указанного типа и поддиректории той 
директории, над которой был произведен 
щелчок. 

Выбор файла осуществляется двойным 
щелчком над именем этого файла в поле 
списка. Просмотр всего списка произво- 
дится с помощью линий прокрутки поля списка или 
клавиш Р^Ир, Р§Оп, ф , ^ , если фокус установлен 
на поле списка. При выборе файла двойной щелчок в 
клавиатурном варианте заменяется на установку мар- 
кера выбора на требуемый файл, а затем нажатие 
клавиши Епіег. 

5. В качестве последнего примера рассмотрим при- 
мер, когда требуется запомнить введенные данные в 
файле В.ТХТ, который уже существует на диске. 

Тем, кто раньше никогда не сталкивался с М5 
^іпсіошз, лучше всего, конечно, познакомиться со сре- 
дой в реальной работе. Тогда все приводимые в книге 
примеры и описания станут более очевидными и по- 
нятными. Данная книга не является теоретическим 
описанием или философским трактатом — она описы- 
вает предмет реальной действительности, который 
можно пощупать руками, увидеть, как он работает*, 
почувствовать. И это, непременно, следует сделать. 


Опишем поля панели диалога, активизируемой ко- 
мандой Ореп... Поле редактирования текста предназ- 
начено для ввода имени файла или типа файла. Поле 
списка содержит все файлы указанного типа, входя- 
щие в текущую директорию; имена дисков в квадрат- 
ных скобках и имен поддиректорий текущей директо- 
рий в квадратных скобках. Если произвести двойной 
щелчок над именем диска, то поле списка будет пере- 
формировано, исходя из списка файлов указанного ти- 
па и директорий, принадлежащих корневой директо- 
рии этого диска. Дройной щелчок можно заменить 


Выделение 

Понятие выделения в М$ АѴіпсІоѵѵз тесно связано с по- 
нятием клипборда (СИрЬоагсІ). Клипборд — это спе- 
циальный буфер для временного хранения информа- 
ции. Копируемая в клипборд информация должна 
быть сначала выделена, а затем уже выполняется ко- 
манда Коп ировать( Сору). Выделяться может как тек- 
стовая, так и графическая (рисунки, графики) инфор- 
мация. 

Выделение может также производиться с целью из- 
менения каких-либо свойств выделяемой 
информации. Характерным примером 
здесь может являться замена в тексте 
шрифтов (фонтов). 

Выделение используется для указания 
нескольких параметров при выполнении 
команды такой, например, как “Копиро- 
вать Файл“. Данная команда может за 
один сеанс производить копирование как 
одного файла, так и группы выделенных 
файлов. 

Выделение производится с помощью 
мыши или клавиатуры. Для пользователя 
процесс визуального выделения заключа- 
ется в маркировании требуемой инфор- 
мации. При выделении текстовых дан- 
ных маркирование производится путем 
реверсивной закраски требуемой облас- 
ти. При выделении графической инфор- 
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мации маркирование представляет собой заключение 
требуемых данных в габаритный прямоугольник. 

Одновременное выделение 
названий нескольких файлов 

Для одновременного выделения названий несколь- 
ких файлов следует нажать клавишу 8ЫП и затем 
осуществить щелчок левой клавиши мыши на нужных 
названиях в списке файлов. 


Одновременное выделение 
названий нескольких файлов 

Для выделения блока (непрерывной последователь- 
ности), файлов следует нажать клавишу 8ЫП и с по- 
мощью функциональных стрелок осущест- 

вить выделение блока. Процесс выделения оканчивает- 
ся после отпускания клавиши 8НІН. 


НИ— М5005 шШЖ 


РИе Ѵіеѵѵ ЗресиІ 

ЯГ =1 В [^=1 ВЕЭІ СЛШИ00ІІ5 
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Выделение “рассыпанных 44 файлов осуществляется 
следующим образом: 

1. Нажать клавишу СІгІ. 

2. Не отпуская Сігі, с помощью функциональных 
стрелок подвести маркер к требуемому файлу. 

3. Отпустить СІгІ. 

4. Нажать 8расе для выделения файла. 

5. Повторить шаги 1-4 для выделения следующих 
файлов. 

Ниже приводится иллюстрация, в которой наглядно 
отображено выделение нескольких “рассыпанных 44 
файлов. 

Выделение текста 

Для выделения текста' следует нажать левую клави- 
шу мыши в месте начала выделения и затем, не от- 
пуская клавишу, осуществлять перемещение мыши. 
При этом в соответствии с перемещением будут изме- 
няться границы реверсивной области закраски. Про- 
цесс выделения завершается освобождением левой 
клавиши мыши. 

Ниже приведена иллюстрация, в которой рассмот- 
рены три последовательных фрагмента выделения тек- 
ста. 


■— И5Р05 
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Выделение текста 

Подвести курсор мыши к месту начала выделения 
текста. Нажать клавишу 8ЫП и, не отпуская ее, ис- 
пользовать функциональные стрелки. При этом будут 
изменяться границы реверсивной области закраски. 
Процесс выделения завершается высвобождением кла- 
виши 8ИІП. 

Выделение текста производят, когда следует изме- 
нить шрифтовое оформление, произвести копирование 
фрагмента текста или его удаление, а также в ряде 
других случаев, когда выделенный текст должен пред- 
ставлять из себя единый неделимый йнформационный 
блок. 

Выделение текста чаще всего производится в тек- 
стовых процессора* и настольных издательских систе- 
мах. В М5 \Ѵіпс1о\ѵ5 недостатка в обработчиках текста 
не имеется — среди них \Ѵогс1 Гог \Ѵіпс1о>ѵ5, Аісіиз 
Ра^еМакег, Аті РгоГеззіопаІ, \Ѵгі1е. 
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Выделение графической информации 
Процесс выделения происходит по тем же принци- 
пам, что и процесс выделения текста. 

Курсор подводится к месту, откуда будет начинать- 
ся выделение, нажимается левая клавиша мыши и 
производится перемещение мыши. При этом изменя- 
ется габаритный прямоугольник выделения. Процесс 
заканчивается после того, как пользователь отпускает 


ко одно активное окно, сфокусированное на работу с 
клавиатурой и мышью. Это окно располагается над 
всеми остальными окнами. 

Активизация окна 

Самым простым способом активизации требуемого 
окна является щелчок левой клавиши мыши в области 
этого окна. 


левую клавишу мыши. 



На иллюстрации представлены два фрагмента экра- 
нов. Первый экран отображает начальный момент вы- 
деления. Второй экран показывает заключительный 
этап. Результатом выделения в итоге явилось изобра- 
жение компьютера. 

Многозадачность М8 \Ѵіп<1<т$. 

Обмен данными между задачами 

Мы уже упоминали о том, что в М5 ХѴіпсІоѵѵз можно 


Активизация окна 

Активизация окна с помощью клавиатуры произво- 
дится комбинациями А\і + Е$с, А\і + 8ЫП + Е$с, 
АК + ТаЪ, АН + ЗЫГС + ТаЬ. Данные комбинации кла- 
виш являются переключателями активных окон. 

Активизируемое окно перерисовывается над всеми 
окнами и его прямоугольник заголовка и окантовка 
приобретает окраску, характерную для активного ок- 
на. 

В М3 ХѴіпсІоѵѵз можно одновременно запускать одну 
и ту же программу несколько раз. При этом в каждом 
из окон одной и той же программы могут обрабаты- 
ваться различные файлы. 

В условиях многозадачности приобретает важное 
значение обмен данными между задачами. Здесь мы 
сталкиваемся еще с одним фундаментальным поняти- 
ем М3 ХѴіпсІоѵѵз — буфером обмена данными 
(СІірЬоагсІ). Буфер обмена данными будем называть 
клипборд. Механизм передачи данных от программы к 
программе в М3 \Ѵіпсіо\ѵ5 крайне прост. Передающая 
эти данные программа копирует эти данные в клип- 
борд, а программа- получатель эти данные из клипбор- 
да забирает. Такая передача осуществляется через 
“Меню Редактирования" (ЕсШ Мели). 


запускать одновременно несколько программ. Каждая 
программа будет высвечивать на экране свое основное 
окно и в результате мы увидим приблизительно следу- 
ющую картину: 
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СА.С.ЕХЕ М5008.ЕХЕ 

САНСШЕ.ЕХЕ -МзІІ СагЛіЫт 

сирѳпо.ЕХЕ 

СШШ..ЕХЕ - 

аЛРАМТ.ЕХЕ ІЕІ-втІ 

ерзом.еэвѵ іеміи 

:::::: рЦпяШокМ 

РЗЫОМЕ.Ра ІлШ . в . я 


С :\Щ N0011$ 

МООЕГО.РОМ МШМР.М 00 I 
МО8СШ.Р0И ѴѴИТЕ.ЕХЕ ■ 

М5005.ЕХЕ і 

^^^іГсісІ^ёэгсЬ ^ ^1 



Эта иллюстрация представляет собой набор пере- 
крывающихся окон. Среди этих окон существует толь- 


\Мо АІІ+Вк$р 
Сіі $№*0еі 
Сору С(гН1пз 
Райе 

Оеаг ОеІ 
Зе(ес(АІ 
Ггпе/Оаіе Р5 
ѴѴог^ѴѴгар 


Команда 
Ѵпдо (отменить) 


Сиі (вырезать) 


Сору (копировать) 


Разіе (вставить) 


Действие 

Отменяет действие 
последней произведен- 
ной команды. 
Копирует выделенные 
данне в клипборд с 
одновременным их 
удалением из области 
данных 

Копирует выделенные 
данные в клипборд 
без удаления. 

Копирует содержимое 
клипборда в область 
данных программы. 
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СІеаг (очистить) Удаляет выделенные данные из 
области данных, оставляя при 
этом клипборд без изменения. 

Заключительные главы, описывающие основные 
принципы работы с М3 АѴіпсіо^ѵз, будут посвящены ра- 
боте с клавиатурой и мышью. В освовном мы уже неп- 
лохо изучили этих устройств в среде М3 ^Ѵіпбоіѵз. Но 
теперь давайте остановимся на них более профессио- 
нально, дадим полный набор функциональных воз- 
можностей работы и с тем, и с другим устройством. 

Клавиатурный интерфейс 

Если у вас нет желания пользоваться мышью или про- 
сто-напросто нет таковой в наличии, М3 АѴіпсІоіѵз 
предоставляет вам развитый клавиатурный интерфейс, 
предназначенный для активизации программы, окна 
или панели диалога; для доступа к системе меню; для 
перемещения окна, изменения его размеров, а также 
для многих других функций. 

Зарезервированные системные ключи 

Зарезервированные системные ключи представляют 
собой комбинации клавиш и используются в М3 
\Ѵіпбо\ѵ5 для реализации различных системных ко- 
манд. Ключи не могут быть переназначены ни одной 
из программ и активны в течение всего сеанса работы 
М3 \Ѵіпбо>ѵ5. В частности, некоторые акселераторы яв- 
ляются такими ключами. Рассмотрим сводную таблицу 
зарезервированных системных ключей. 

Ключ Действие 

АН+Р4 Закрывает окно 

АИ, Зрасе Выбрать Контрольное Меню активного 
окна (запятая между клавишами 
означает, что вначале следует 
нажать и отпустить первую клавишу, 
а затем нажать и отпустить 
вторую клавишу). 

ЗЫН+Езс Выбрать Контрольное Меню активного 

окна (“+“ между клавишами означает, 
что следует нажать первую клавишу, 
а затем, не отпуская ее, нажать 
вторую клавишу). 

АИ+ТаЪ Переключение между текущим активным 

окном и окном, которое было активным 
до него. При переключении икона 
восстанавливается до окна. 
АИ+5НіН+ТаЪТо же самое, но в обратном 
направлении. 

АИ+Езс Переключиться на следующую 

запущенную программу, двигаясь в 
прямом направлении последователь- 
ности запуска программ. 

АИ+ЗЬіН+Езс Переключиться на предыдущую 
запущенную программу, двигаясь 
в обратном направлении после- 
довательности запуска программ. 


АН+Р5 Восстановить окно до его 

первоначального размера. 

АИ+Р7 Перемещение окна. 

АИ+Р8 Изменение размеров окна. 

АИ+Р9 Убрать окно и высветить вместо 

него икону. 

РІО или АИ Перейти к системе меню. 

Далее рассмотрим таблицу ключей для использова- 
ния меню: 

Ключ Действие 

ЬЕРТ — Перемещение к следующему меню 

системы меню или переход к 
следующему выпадающему меню. 
Движение осуществляется справа 
налево. 

КЛСНТ — Перемещение к следующему меню 

системы меню или переход к. 
следующему выпадающему меню. 
Движение осуществляется слева 
направо. 

ѴДР I Выбрать пункт меню, располо- 

женный над выбранным пунктом. 

ООАѴЫ I Выбрать пункт меню, располо- 

женный под выбранным пунктом. 

Епіег Выполнить команду, соответству- 

ющую выбранному пункту меню. 

Езс Отказаться от работы с меню. 

Следующая таблица описывает ключи для работы с 
панелями диалога: 

Ключ Действие 

ТаЬ Перемещение к следующему полю или 

группе. Движение осуществляется 
слева направо и сверху вниз. 

ЗНіН+ТаЬ Перемещение к следующему полю или 

группе. Движение осуществляется 
справа налево и снизу вверх. 

Зрасе Активизация командной кнопки. 

Изменение состояния выключателя. 

Епіег Выйти из панели диалога, активизиро- 

вав выделенную командную кнопку. 

Езс Отменить работу панели диалога. 

Следующая таблица описывает ключи для выполне- 
ния функций редактирования, перемещения и выделе- 
ния: 

Ключ Действие 

ТаЬ Перемещение к следующему пункту 

слева направо и сверху вниз. 
Перемещение текста вправо на один 
табулятор. 

ЗНіН+ТаЬ Перемещение к следующему пункту 
справа налево и снизу вверх. 
Перемещение текста влево на один 
табулятор. 

Епіег Выполнить команду, установленную 

по умолчанию. Начать новый абзац в 
документе. 
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->, Ф; ^ Перемещение в соответствии со 

значением функциональной стрелки. 

Сіг1+<- Переместиться влево или в начало 

группы или секции. 

СІГІ+-* Переместиться вправо или в конец 
группы или секции. 

Сіг1+? Переместиться вверх или в верхнее 

положение группы или секции. 

Сіг1+* Переместиться вниз или в нижнее 

положение группы или секции. 

5НіН+Сіг1+<- Переместиться и расширить выделение 
влево или в начало поля, группы 
или секции. 

5ЬіН+Сіг1+-> Переместиться и расширить выделение 
вправо или в конец поля, группы 
или секции. 

ЗНіН+СігІ+Ф Переместиться и расширить выделение 
вверх или в начало поля, группы 
или секции. 

5ЫН+СІГІ+* Переместиться и расширить выделение 
вниз или в конец поля, группы 
или секции. 

Р|Щр Осуществить прокрутку вверх 

на один экран. 

Р^Оп Осуществить прокрутку вниз на 

один экран. 

СігІ+Р^ІІр Осуществить прокрутку влево на 

один экран. 

Сігі+РеЭп Осуществить прокрутку вправо 

на один экран. 

ЗНіИ+Р^р Осуществить прокрутку и расширить 

выделение вверх на один- экран. 

ЗЫН+Р^Оп Осуществить прокрутку и расширить 

выделение вниз на один экран. 

5ЬіН+<- Переместиться и расширить выделение 

влево на одну единицу измерения. 

ЗЫН+-> Переместиться и расширить выделение 

вправо на одну единицу измерения. 

Іп5 Переключатель моды вставка/ замена. 

ЗНіН+Іпз Вставить содержимое клипборда. 

Сігі+Іпз Копировать выделенную информацию 

в клипборд. 

Оеі Удалить выделенную информацию. 

Сігі+Оеі Удалить с текущей позиции до 

конца строки. 

ЗНіН+ОеІ Удалить выделенную информацию 

и поместить ее в клипборд. 

Васкзрасе Удалить символ или пробел 

слева от курсора. 

АИ+ Отменяет последнее действие 

Васкзрасе редактирования. 

Ноте Перемещение в начало строки. 

Сігі+Ноте Перемещение в начало данных. 

ЗЫН+Ноте Переместиться и расширить 

выделение до начала линии. 

ЗЫН+ Переместиться и расширить 

Сігі+Ноте выделение до начала данных. 

Епб Переместиться в конец строки. 

Сігі+Епб Переместиться и расширить 


выделение до конца строки. 

5ЫН+ Переместиться и расширить 

Сіг1+Еп<3 выделение до конца данных. 

Следует уяснить одно простое правило: клавиша 
8ЫН используется для выделения необходимой инфор- 
мации. 

Интерфейс мыши 

В М3 АѴіпсІодѵз использование мыши является альтер- 
нативным методом управления. Это не является огра- 
ничением ее применения, а наоборот, практически 
всегда использование мыши делает управление более 
простым и доступным. 

Управление мышью фактически сводится к четырем 
действиям: 

Действие Описание 

Установка (роіпО Передвинуть мышь, чтобы курсор 
мыши указывал на требуемое 
место или поле. 

Щелчок (рііск) Быстро нажать и отпустить 

клавишу мыши. 

Тащить (бга^) Нажать левую клавишу мыши и, 

не отпуская ее, осуществлять 
перемещение мыши. 

Двойной щелчок Быстро щелкнуть клавишей 
(боиЫе-сІіск) мыши дважды. 

В М3 >Ѵіпбо^ѵз мышь используется: для доступа к 
меню; для активизации программы; для перемещения 
окна, изменения его размеров; для закрытия окна или 
трансформации окна в икону и т.д. 

Обычно во всех программах используется только ле- 
вая клавиша мыши. Другие клавиши применяются в 
ситуациях, оговариваемых в специальных инструкциях 
к программам. 

Рассмотрим подробно, использование мыши в ситуа- 
циях выделения информации и выбора пунктов. 

При работе по выделению текста существуют следу- 
ющие соглашния об использовании мыши: 

Действие Описание 

Сііск Щелчок Перемещает текстовый курсор в 

место, на которое указывает 
курсор мыши. 

Двойной щелчок Выделить слово. 

ВЫДЕЛЕНИЕ Выделять текст, начиная с того 

Тащить места, где клавиша мыши была 

нажата, до места, где клавиша 
отпускается. 

ЗНіН+СІіск Осуществляет выделение от 

текстового курсора до того места, 
куда указывает курсор мыши. 

Сіг1+ Первоначально выделяется область 

ВЫДЕЛЕНИЕ в границах от текстового курсора 

до курсора мыши, а затем при 
перемещении мыши данная область 
выделения изменяется. 
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Виды курсоров мыши 

В зависимости от типа выполняемого действия фор- 
ма курсора мыши может изменяться, тем самым сиг- 
нализируя о выполнении соответствующего типа дей- 
ствия. 

Приведем самые распространенные виды курсоров 
мыши: 

Вид Описание 

Курсор мыши в виде стрелки. 

Имеет место при работе с меню, 
панелями диалога, линиями 
прокрутки и т.д. 

I Соответствует текстовому курсору. 

И Курсор — песочные часы. Сигнализиру- 

ет о процессе обработки информации и 
задержке выдачи данных на экран. 

Некоторые подробности об окнах 

Как мы уже рассматривали, каждая программа име- 
ет свое основное окно. Это и только это окно иденти- 
фицирует программу. Сколько запущено программ, 
столько и будет на экране окон. Некоторые окна могут 
быть невидимыми, так как либо другие окна их пере- 
крывают, либо эти окна заменены иконами (спрятаны 
в иконы). 

Помимо основного окна программа в случае необхо-, 
димости может открывать сопутствующие ее работе 
дополнительные окна. Эти окна называются вторичны- 
ми (сНіІгі) окнами. Вторичные окна могут иметь те же 
атрибуты, что и основные окна, кроме меню. Коли- 
чество открываемых вторичных окон лимитируется 
только техническими возможностями компьютера, но 
не идеологией М3 \ѴіпсІо>ѵ5. 

Понятие фокуса и активного окна полностью рас- 
пространяется на вторичные окна. Управление вторич- 


ными окнами совпадает с управлением вторичными 
окнами. Панели диалога и сообщений в конечном ито- 
ге также являются вторичными окнами, но выделяют- 
ся в отдельный класс, поскольку имееет ярко выра- 
женные специфические характеристики в виде полей 
и кнопок. 

При работе со вторичными окнами следует всегда 
помнить о том, что при закрытии основного окна за- 
крываются все вторичные окна, принадлежащие этому 
окну. 

Самая последняя глава 

Итак, мы рассмотрели все основные понятия М3 
>Ѵіп(1одѵз и немного научились работать с этой средой. 
Если вам показалось приведенное описание слишком 
сложным и отпугнуло от М3 \Ѵгп<іоаѵ5, не отчаивай- 
тесь. Наверняка вы оказались в такой ситуации, когда 
у вас не было под рукой самой среды М3 \Ѵіпс1о>ѵ5 или 
вы все время читали эту книгу в переполненном авто- 
бусе или метро. Вам просто сложно было переклю- 
читься от будничных дел к освоению М3 \Ѵіпгіо>ѵз. Не 
торопитесь делать поспешные выводы — отложите не- 
надолго эту книгу, а затем, через некоторое время 
снова к ней вернитесь. Среда М3 ДѴіпс1о\ѵз действи- 
тельно достойна вашего внимания! Хорошие знания об 
этой среде никогда не помешают вам в будущем. 

Следующая часть этой книги посвящена описанию 
конкретных программ для М3 \Ѵіпс1о\ѵ5. Среди них 
текстовый процессор, электронная картотека и ряд 
других программ. 

Следующая часть уже может рассматриваться вами 
как справочное руководство. Опыт работы с М3 
\Ѵіпс1о^ѵ5 показывает, что знание основополагающих 
принципов работы среды позволяет в самые короткие 
сроки, практически без описания освоить любую про- 
грамму, работающую в М3 ^Ѵіпскпѵз. Чем и хороша 
настоящая среда, что стандартизует весь пользователь- 
ский интерфейс независимо от специфики решаемых 
задач. 


( Продолжение следует ). 


Зарплата работающих в американской компьютерной 
индустрии растет... 

По данным исследований, проведенных международной 
ассоциацией менеджеров сервиса (АРЗМІ), сервис, в том 
числе и информационный, в последнее время приносит 
все возрастающую прибыль многим компаниям, что позво- 
ляет увеличивать заработную плату работающих в АРЗМІ. 

Среднегодовая зарплата директора по техническому об- 
служиванию выросла с 35500 долл, в 1980 году до 70700 
долл, в 1990 году. 

Среди технических работников самой высокооплачивае- 
мой должностью остается старший инженер по аппаратно- 
му обеспечению. Зарплата на этой должности за послед- 
ние 10 лет выросла с 24 до 43 тысяч долл, в год. Заработ- 


ная плата других представителей этой профессии в 1990 
году была следующей: старший инженер по обслужива- 
нию пользователей — 32500, старший техник-ремонт- 
ник — 28700, техник-ремонтник — 23000 долл, в год. 

В разных местах зарплата также существенно различа- 
ется. В Калифорнии она самая высокая. 

ЫежЬуІез Ыепз ІЯеіѵюгк, МагсН 75, 1991. 

Несмотря на то, что объявленная в Сан-Хосе, Калифор- 
ния, выставка изделий для ЛѴіпсІолѵв и 03/2 состоялась, 
последним в экспозиции места не нашлось. Впрочем, посе- 
тителей это ничуть не огорчило. 

Сотри1егѵюгІ(1 , МагсН 77, 1991. 
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В наше время истинным бедствием для 
компьютеров и их программного 
обеспечения стали многочисленные 
компьютерные вирусы. По мере 
накопления опыта борьбы с вирусами 
начали возникать целые антивирусные 
технологии работы с компьютерами. 
Одним из эффективных средств 
предохранения от возможных потерь 
информации является защита 
логических дисков. 


Программная защита 

дисков 


Защита логических дисков винчестера 

Едва ли не самой обсуждаемой темой в мире ІВМ-сов- 
местимых персональных компьютеров становится 
проблема компьютерных вирусов. Существует несколь- 
ко типов программ, предназначенных для борьбы с ви- 
русами. Самые необходимые и широко распространен- 
ные из них — это детекторы и доктора вирусов. Один 
из наиболее популярных в нашей стране пакетов 
подобного типа — Зсап/СІеап ассоциации МсАГее. 
Имеются также полифаги, сочетающие в себе оба ука- 
занных свойства, лучшим примером которых будет, 
несомненно, АШ5ТЕ5Т Д.Лозинского. Однако у всех 
таких программ есть одно уязвимое место — они не- 
способны бороться против неизвестных им вирусов, 
как неспособны и защитить другие программы от за- 
ражения ими. Следовательно, необходимо попробовать 
защитить свои файлы, хранящиеся на винчестере, 
против атак вирусов другим способом. 

Идея создания резидентной антивирусной програм- 
мы родилась почти одновременно с появлением самих 
компьютерных вирусов. Первые такие программы дей- 
ствительно эффективно обнаруживали попытки неле- 
гальной записи на диск. Однако авторы вирусов доста- 
точно быстро справились с таким “досадным недоразу- 
мением 44 и перестали пользоваться прерыванием 21 И 
для записи в программу своего кода, обратившись на- 
прямую к прерыванию ІЗЬ. Перестроились и антиви- 


русные программы, которые стали проверять теперь 
именно это прерывание. 

Но вот в последнее время появились сообщения о 
создании двух новых классов компьютерных вирусов. 
Первые из них используют функцию 1300Н прерыва- 
ния 2РН для получения первоначального адреса пре- 
рывания 1 ЗН, имевшегося еще до загрузки ЭОЗ. Вто- 
рые вначале проходят процедуру записи в пошаговом 
режиме, добираясь до адресов ВІ05, перехватывают 
управление и в дальнейшем осуществляют запись, об- 
ращаясь уже непосредственно к контроллеру. 

Для успешной борьбы с современными вирусами 
антивирусная программа должна обладать высокими 
“интеллектуальными 44 способностями, что, как прави- 
ло, сопряжено с большим объемом исполняемого кода. 
В результате такая программа может сильно замедлять 
работу с винчестером и было бы нежелательно исполь- 
зовать ее постоянно. Поэтому к серьезной антивирус- 
ной программе целесообразно обращаться лишь в слу- 
чае возникновения реальной опасности заражения. В 
остальное же время очень полезной могла бы оказать- 
ся маленькая резидентная программа, способная защи- 
щать винчестер от “пиратских 44 попыток записи на 
уровне прерывания 1 ЗН. Эту задачу и выполняет пред- 
лагаемая вашему вниманию программа РКОТЕСТ. 

РКОТЕСТ является резидентной программой защи- 
ты винчестера от записи. Защищается не весь винчес- 
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тер, а лишь отдельные его участки, определяемые ци- 
линдрами, на которые распространяется запрет запи- 
си. Такой подход позволяет осуществлять вызов 
РКОТЕСТ из файла АІІТОЕХЕС.ВАТ и защищать 
только системные логические диски винчестера. Даже 
в случае если на вашем диске уже имеются вирусы, 
они не смогут произвести свое разрушительное 
действие и заразить новые программы. При этом все 
остальные логические диски остаются открытыми 
для записи и на них можно спокойно работать. Про- 
грамма РКОТЕСТ полезна также и против “тро- 
янских“ программ, разрушающих системную инфор- 
мацию. 

У программы РКОТЕСТ есть одно слабое место — 
она загружается через 005 и поэтому не может пре- 
пятствовать заражению винчестера Ьооі-вирусами. Тем 
не менее, вы можете избежать и этой беды, используя 
программу Ѵііатіп-В (автор А. Сесса), которая разра- 
ботана для вакцинации областей ВООТ и РагШіоп 
ТаЫе. Некоммерческая версия программы распростра- 
няется через Софтпанораму. Последняя версия избав- 
лена от досадных ошибок, которые ранее в отдельных 
случаях приводили к уничтожению некоторых ло- 
гических дисков, при работе с ПОЗ версий старше 
3.30. Программа Ѵііатіп-В является отличным 
средством защиты от Ьооі-вирусов; комбинируя ее 
вместе с РКОТЕСТ, вы получите на своем ком- 
пьютере программную среду, устойчивую к вирусным 
атакам. 

РКОТЕСТ не имеет ключей запуска. Это связано с 
требованиями минимального размера и максимального 
быстродействия резидентной программы, непрерывно 
проверяющей все операции с винчестером. Вместо 
ключей вы просто указываете количество защищаемых 
цилиндров в приведенном ниже исходном тексте про- 
граммы и заново компилируете ее (например, ТигЬо 
АззешЫег'ом). Для минимизации кода программы в 
ней не предусмотрены какие бы то ни было встроен- 
ные средства отключения защиты. Эту задачу выпол- 
няет отдельная программа РКОТОРР, которая сама не 
загружается резидентно, а лишь проверяет при своем 


запуске наличие РКОТЕСТ в памяти компьютера и 
переключает защиту из активного состояния в пассив- 
ное и наоборот. 

В целях борьбы с вирусами нового поколения 
РКОТЕСТ осуществляет вызов функции 1300Н преры- 
вания 2РН, заменяя в таблице старый адрес прерыва- 
ния 13Н ложной информацией. Если в дальнейшем 
какой-либо вирус попытается обойти РКОТЕСТ, то он 
получит неверный адрес прерывания 1 ЗН и неизбежно 
“завесит 44 компьютер, пытаясь провести запись на 
диск. На мой взгляд, нажатие кнопки КЕ5ЕТ не бу- 
дет чрезмерной платой за успешное отражение вирус- 
ной атаки. А связанные с этим потери информации 
будут неизмеримо меньшими в сравнении с теми раз- 
рушениями, которые вам причинил бы проникший в 
систему вирус. 

Если у вас есть необходимость защитить логические 
диски, расположенные на винчестере не по порядку, а 
выборочно, то код программы легко модифицировать, 
изменив условия проверки на те или иные группы ци- 
линдров. 

Необходимо отметить, чтр программа РКОТОРР на- 
строена на смещение ключевого байта, вырабатывае- 
мое при компиляции ТигЬо АззетЫег'ом версии 2.0 и 
старше. Если вы пользуетесь другим компилятором, то 
возможно, вам придется исследовать ТигЬо 
ЭеЬи^ег ом или каким-либо другим отладчиком типа 
(Зиаісі Апаіухег работу РКОТЕСТ и найти в ней то 
место, где размещается ключевой байт. При наличии 
отладочной информации по программе это не составит 
большого труда. 

След/ет также иметь в виду, что если поверх 
РКОТЕСТ вы разместите другую резидентную про- 
грамму, которая переустанавливает вектор прерывания 
13Н на себя, то РКОТОРР не сможет найти РКОТЕСТ 
в памяти и выдаст сообщение об ошибке. Будьте вни- 
мательны при размещении в памяти ваших резидент- 
ных программ — и у вас не возникнет никаких проб- 
лем с работой комплекса РКОТЕСТ. 

/О. Краоацкий 


; Защита логических дисков винчестера методом 
; установки альтернативной программы обработки 
; прерывания 1 ЗН, запрещающей запись на указанные 
; цилиндры. 

; Рго^гат \ѵаз ѵтііеп Ьу ДѴК ЗоГішаге. 

; АП гі^іЬз гезегѵесі. Апрель 1991 

; Эта программа является Ггееѵѵаге и может 
; передаваться в неизмененном виде всем 
; пользователям в некоммерческих целях. Для 
; контакта с автором звоните по телефонам: 

; 135-99-07 (Москва), 477-13-24 (Киев) 

; Кравацкий Юрий Всеволодович 

$у$_$ігеечи 400 ; Количество защищаемых 

; цилиндров 


сосіе зе^тепірага риЫіс 



аззшпе 

СЗ:сосіе 


ог8 

100Н 

зіап: 

ітр 

іпзіаІІ 

іпіІЗН 

ргос 

пеаг 


СІІ 

; Запретить прерывания 

; Проверка прерывания 1 ЗН на все функции записи 

стр АН,03Ь ; >ѵгііе зесіог (запись сектора) 

Іе пехісЬк 

Ітр гипІЗЬ 

стр АН,0РН ; АТ \т\е зесіог (запись 

; сектора на АТ) 
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іе 

пехІсНк 


стр 

АН,0ВН ; 

мѵгііе Іоп^ (длинная запись) 

Іпе 

гипІЗН 


пехІсНк: 



стр 

ОЦ80Н ; 

Проверка обращения к Нагсі 
сігіѵе 0 (первому винчестеру) 

.Іпе 

гипІЗН 


ризН 

сх 


гоі 

СЦ1 


гоі 

СЬ,1 


хсНз 

сцен 


апб 

СХ,03РЕН 


стр 

СХ,зуз зіге; Находимся ли мы в 



; защищаемых пределах 

№ 

гипНеге 

; Нет 

рор 

СХ 


тоѵ 

С5:заѵе а!,АЬ 

рор 

АХ 


тоѵ 

С5:ге1 оГГ,АХ 

рор 

АХ 


тоѵ 

С5:геІ зев,АХ 

рор 

АХ 

; Сохранить флаги 

тоѵ 

АЬ,СЗ:заѵе аі 

тоѵ 

АН,3 

; Выставить для 003 ошибку 



; “ЛѴгііе ргоІесГ 

зіі 


; Разрешить прерывания 

8 (С 


; Установить Саггу-флаг для 
; индикации ошибки 

<1Ь 

ОЕАН 

» 

Первый байт инструкции 
Гаг ]итр 

геІоГГ сіѵѵ 

0 


геізе^ сіѵѵ 

0 


гипНеге: 



рор 

сх 


гипІЗН: 



зіі 



дЬ 

ОЕАН ; 

Первый байт инструкции 
Гаг ]итр 

оШІЗо сіѵѵ 

0 ; 

В этих двух переменных 

оісііЗз сіѵѵ 

0 ; 

храните^ старый адрес 
прерывания 13Н 

заѵе^аі дЪ 

0 


іпіІЗН епсір 



іпзіаіі ргос 

пеаг 


ризН 

ЭЗ 

; .Этот блок предназначен для 

ризН 

ЕЗ 

; борьбы с вирусами. 

тоѵ 

АХЛ300Н 

; использующими ту же 

іпі 

2РН 

; функцию для получения 

стр 

ох,вх 

; адреса прерывания 13Н, 



; существовавшего до 
; загрузки ЭОЗ. После этого 
; прерывание 2РН будет 
; возвращать ложный адрес 
; прерывания 13Н. 

,Іпе 

аігеасіу^іоасі 

тоѵ 

АХ.2513Н 

; Восстановление 

ІПІ 

21Н 

; разрушенного адреса 
; прерывания 13Н 

рор 

ЕЗ 


рор 

ИЗ 


ризН 

ЕЗ 

; Подготовка и 

тоѵ 

АХ,ЭЗ: [2сН] ; освобождение ПОЗ 



тоѵ 

Е8,АХ ; епѵігоптеп! 


тоѵ 

АН,49Н ; для уменьшения 


іпі 

21 Н ; размера резидентной 

; части программы 


рор 

ЕЗ 


ризН 

БЗ 


ризН 

ЕЗ 


тоѵ 

АХ,3513Н ; Запомнить адрес 

; прерывания 13Н 


іпі 

21Н 


тоѵ 

С5:о1с113о,ВХ 


тоѵ 

СЗюІсІІЗз.ЕЗ 


сН 

; Запретить прерывания 


тоѵ 

АХ,С5 


тоѵ 

03,АХ 


Іеа 

ох.іпіізн 


тоѵ 

АХ,2513Н ; Установка нового адреса 


іпі 

21 Н ; прерывания 13Н 


зіі 

; Конец блока настройки 003, 
; разрешить прерывания 


рор 

ЕЗ 


рор 

ЭЗ 


тоѵ 

ОХ.оГГзе! іпзіаіі; Установить 


іпі 

27Н ; резидентную часть 

; программы 

а!геас1у_1оас1: 



рор 

ЕЗ 


рор 

геі 

БЗ 

іпзіаіі 

епсір 


сосіе 

епсіз 



епсі 

зіап 


; Программа переключения комплекса РКОТЕСТ из 
; активного состояния защиты в пассивное и наоборот. 

; Проверяет первые 6 байт кода прерывания 13Н. Если 
; они совпадают с кодом в РКОТЕСТ, то производится 
; переключение ключевого байта из одного состояния в 
; другое. 

; ТНіз рго&гат іѵаз \ѵгіиеп Ьу ДѴК ЗоГіѵѵаге. 

; АН гі^Ыз гезегѵеб. Декабрь 1990 

; Эта программа является Ггеешаге и может 
; передаваться в неизмененном виде всем 
; пользователям в некоммерческих целях. 

; Автор Ю. Кравацкий 

сосіе зе^тепі рага риЫіс 

аззите СЗ ходе, И5: сосіе 

ОГ8 100Н 

зіагі: 

ризН ЕЗ 

тоѵ АХ.3513Н 

іпі 21 Н ; Получить адрес 

; прерывания 13Н 
тоѵ АХ,*юг<1 ріг ЕЗ:ВХ 

стр АХ,080РАН ; Проверка первого слова 

Іпе по_ргоіесі ; кода протектора 

іпс ВХ 

іпс ВХ 
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шоѵ 

АХлѵогсі ріг Е8:ВХ 



; записи 

стр 

АХ,003РСЬ 

; Проверка второго слова 

Іеа 

ОХ,ргоі тезза^е 

; Выдать сообщение о 

Іпе 

по_ргоІесІ 

; кода протектора 

тоѵ 

АХ.0900Н 

; запрете записи 




іпі 

21 Н 


іпс 

ВХ 


ітр 

ехіі 


іпс 

вх 





тоѵ 

АХ,\ѵогсІ ріг Е5:ВХ 

по_ргоІесі: 



стр 

АХ,00С74Н 

; Проверка третьего 

Іеа 

ОХ,по_ргоІ тезз 

; Выдать сообщение о 

Іпе 

по_ргоіесІ 

; слова кода протектора 

тоѵ 

АХ.0900Н 

; том, что 




іпі 

21Н 

; резидентная часть 

тоѵ 

ВХ,01 17Н 

; Загрузить в ВХ смещение 



; РКОТЕСТ в памяти 



; ключевого байта 



; не обнаружена 

тоѵ 

АН,ЬуІе ріг Е5:ВХ 

Ітр 

ехіі 


стр 

АН,075Н ; 

Защита записи включена? 




І е 

ипргоіесі 


Ьас1_ргоІесІ: 



стр 

АН,ОЕВН ; 

Защита записи выключена? 

Іеа 

ОХ.ЪасІ тезза^е 

; Выдать сообщение о 

І е 

ргоіесі 


тоѵ 

АХ,0900Н 

; несоответствии 

Ітр 

Ьас1_ргоІесІ 

; Несогласованные версии 

іпі 

21Н 

; версий РКОТЕСТ и 


; РКОТЕСТ и РКОТОРР 



; РКОТОРР 

ипргоіесі: 



ехіі: 



тоѵ 

АН,0ЕВН 

; Установить 

рор 

ЕЗ 


тоѵ 

Ъуіе ріг Е8:ВХ,АН; ключевой байт 

геі 





; в состояние 






; разрешения записи 

по_ргоі_тезз 

<ІЪ РКОТЕСТ поі Іоипсі!', ООН, ОАН, 

Іеа 

ОХ,ипрго_тезза8е ; Выдать сообщение о 

Ъагітеззаяе 

6 Ь ТІпкпошп РКОТЕСТ ѵегзіоп!' 

тоѵ 

АХ.0900Н 

; разрешении записи 


аь <ШЬ, ОАЬ, •$• 


іпі 

21 Н 


ипрго_те8$а^есІЪ Нагд сіізк ргоіесііоп із по\ѵ ОРР' 

ітр 

. ехіі 



<1Ь (ЮЬ, ОАЬ, •$' 





ргоітеззазе 

6 Ъ 'Нагсі сіізк ргоіесііоп із по\ѵ 0№ 

ргоіесі: 




аь оэн, оаь, $• 


тоѵ 

АН,075Н 

; Установить 




тоѵ 

Ъуіе ріг Е5:ВХ,АН; ключевой байт 

епсіз 





; в состояние запрета 

епс! 

8 іа И 



Программная защита гибких дисков 

В некоторых случаях возникает необходимость про- 
граммной защиты от записи также и дисководов гиб- 
ких дисков. Это может понадобиться, например, если 
вы по каким-либо причинам не хотите “заклеивать" 
дискету, но хотите вместе с тем иметь гарантию, что 
на нее не будет произведена никакая запись. Помимо 
этого иногда бывает необходимо полностью запретить 
обращение к флоппи-дисководам, например, для за- 
щиты их от несанкционированного доступа. Последняя 
операция имеет смысл только в том случае, когда нет 
возможности перезагрузить компьютер с дискеты (на 
некоторых компьютерах это предусмотрено аппарат- 
но). Однако не слишком квалифицированных пользо- 
вателей подобная мера обычно все равно приводит в 
полнейшее замешательство и отбивает всякую охоту к 
дальнейшим экспериментам. 

Предлагаемая программа РЬРТ (РІорруРгоіесІ) по- 
зволяет выполнять указанные выше действия. Имеют- 
ся три режима работы программы — с защитой флоп- 
пи -дйсководов только от записи, полным запретом об- 
ращения к флоппи-дисководам и режим отключенной 
защиты, в котором чтение и запись разрешены. 

Переключение режимов защиты осуществляется вы- 
зовом той же программы РІорруРгоіесІ с соответствую- 
щей опцией в командной строке. Список возможных 
опций имеется в тексте программы. Если была задана 
неверная опция, либо если программа была запущена 


вообще без каких-либо ключей, то на экран будет вы- 
веден список разрешенных опций. 

При каждом запуске программы вначале осущест- 
вляется проверка наличия в памяти ее резидентной 
части. Таким образом, резидентная часть программы 
может быть загружена только один раз, а при после- 
дующих запусках будет производиться лишь переклю- 
чение режимов защиты. 

Для отслеживания в памяти резидентной части про- 
граммы, а также для переключения режимов защиты 
используется нестандартная функция 77Н прерывания 
13Н (номер функции выбран произвольно). В програм- 
ме имеются специальные участки кода, надлежащим 
образом реагирующие на вызов функции 1 ЗН, 77Н. 
При этом выполняются нужные переключения и осу- 
ществляется возврат необходимых значений. 

Благодаря такому техническому приему, программа 
РІорруРгоІесі становится независимой от работы дру- 
гих резидентных программ, загружаемых в память по- 
сле нее и тоже использующих прерывание" 1 ЗН. 

Следует иметь в виду, что программа РІорруРгоІесі 
устанавливает защиту сразу на все флоппи-дисководы, 
подключенные к вашей системе. Если вы хотите иметь 
возможность устанавливать защиту избирательно — 
измените соответствующим образом нужные участки 
программы. 

А. Синев 
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ПРОГРАММНАЯ ЗАЩИТА ДИСКОВ 
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РИЖСКИЙ ТЕХНИЧЕСКИЙ УНИВЕРСИТЕТ И 
ЛАТВИЙСКИЙ ЦЕНТР АНТТ 

ПРЕДЛАГАЮТ 

ИНСТРУМЕНТАЛЬНЫЙ ПАКЕТ ДЛЯ СОЗДАНИЯ 
ОБУЧАЮЩИХ СИСТЕМ, УЧЕБНЫХ КУРСОВ, 
ПРОГРАММНЫХ ТРЕНАЖЕРОВ 


Пакет работает как на автономной ПЭВМ класса ІВМ РС, так и в составе 
локальной сети. 

Отличительные особенности пакета: 

высокие дидактические возможности по планированию и управлению учеб- 
ными занятиями; 

реализация различных методов оценки уровня подготовленности обучаемых; 
адаптация к пользователю; 

развитые средства работы с моделями объективов и динамической графики; 
удобные формы диалога и др. 

АВТОМА ВИЗИРОВАННЫЙ УЧЕБНЫЙ КУРС ГЮ ОСНОВАМ 
ТЕОРИИ АВТОМАТИЧЕСКОГО УПРАВЛЩШК МК ЩВМ. 

Основной акцент в курсе сделан на развитие практических навыков анализа 
структурных схем, оценки устойчивости, расчетов переходных процессоров 
и т.п. 


РАЗРАБОТКУ АППАРАТНО-ПРОГРАММНЫХ СРЕДСТВ 
ЛОКАЛЬНОЙ СЕТИ ПЭВМ, 


реализуемой на основе встроенной платы в конструктиве ІВМ РС и обес- 
печивающей скорость передачи данных до 1 Мбод. 

ПРОГРАММНО-АППАРАТНЫЙ КОМПЛЕКС СВЯЗИ ЕС - ПЭВМ по ценам 
ниже рыночных. 


ВЫСОКОКВАЛИФИЦИРОВАННЫЙ КОЛЛЕКТИВ, ИМЕЮЩИЙ 
БОЛЬШОЙ ОПЫТ В РАЗРАБОТКЕ ОБУЧАЮЩИХ СИСТЕМ И 
ПРОГРАММНЫХ ТРЕНАЖЕРОВ ПРЕДЛАГАЕТ СВОИ УСЛУГИ! 


Адрес: 226050, Рига, Дзирнаву, 59. Телефоны: (0132)280539, 285425. 
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Язык логического 
программирования 

МПРОЛОГ 


1. Что такое МПРОЛОГ? 

МПРОЛОГ — язык модульного логического про- 
граммирования. Название МПРОЛОГ образовано от 
слов Модульное Программирование Логическое. 

Язык МПРОЛОГ предназначен для решения задач, 
относящихся к проблематике искусственного интел- 
лекта. К числу таких задач относятся создание эк- 
спертных систем и инструментальных средств для их 
разработки, систем автоматизированного проектирова- 
ния с элементами искусственного интеллекта, созда- 
ние интеллектуальных баз данных, автоматическое до- 
казательство теорем и т.п. 

В настоящее время язык МПРОЛОГ уже подучил 
очень широкое распространение для решения различ- 
ных задач в таких областях, как машиностроение, 
приборостроение, химия, медицина, архитектура и т.д. 

На языке МПРОЛОГ создан ряд экспертных систем 
в различных прикладных областях. 

2. В чем отличие МПРОЛОГа 

от алгоритмических языков ? 

Язык МПРОЛОГ принципиально отличается от 
традиционных алгоритмических языков програм- 
мирования тем, что в нем требуется описывать логи- 
ческую модель предметной области решаемой задачи в 
терминах объектов, их свойств и отношений между 
объектами без подробного описания самого алгоритма 
решения задачи. 

Программа на языке МПРОЛОГ состоит из мно- 
жества утверждений. Каждое из утверждений является 
либо некоторым фактом о заданной предметной облас- 
ти, либо правилом, указывающим, как решение связа- 
но с имеющимися в программе фактами или каким 
образом это решение можно получить из имеющихся 
фактов. 

В основу языка МПРОЛОГ положены идеи логичес- 
кого программирования. 


3. В чем особенности языка МПРОЛОГ ? 

Язык МПРОЛОГ является одной из наиболее из- 
вестных и широко распространенных версий языка ло- 
гического программирования Пролог. 

Основные характерные черты языка МПРОЛОГ : 

— возможность использования концепций модуль- 
ного логического программирования при создании про- 
грамм, что позволяет создавать большие программы, 
состоящие из модулей, а также вести разработку боль- 
ших программных систем по частям и т.п.; 

— большой набор встроенных предикатов ( более 
150) и операторов (более 50), выполняющих различ- 
ные функции и существенно облегчающих програм- 
мирование на языке МПРОЛОГ ; 

— наличие набора функций трехмерной машинной 
графики; 

— возможность программирования пользователем 
реакции системы на ошибки, возникающие во время 
выполнения его программ; 

— наличие интерфейса с традиционными проце- 
дурными языками программирования, такими как Си, 
Паскаль, Фортран, Кобол, Ассемблер, что значительно 
расширяет функциональные возможности системы и 
повышает ее эффективность; 

— совместимость программ, написанных на языке 
МПРОЛОГ, для различных типов ЭВМ; 

— наличие мощной и удобной системы поддержки 
разработки программ на языке МПРОЛОГ, включаю- 
щей в себя редактор текстов и отладчик; 

— возможность создания больших программ благо- 
даря тому, что интерпретатор имеет большие таблицы 
(т.е. фактически не накладываются ограничения на 
размер программ, допускается использование имен пе- 
ременных любой длины ); 

— эффективный по времени и памяти механизм 
выполнения программ, заложенный в интерпретаторе 
и включающий в себя, например, такие средства, как 
хвостовая рекурсия, управление поиском и т.п.; 
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— допустимость компиляции и оптимизации разра- 
батываемых на языке МПРОЛОГ программ с целью 
повышения их эффективности по времени и занимае- 
мой памяти ; 

— возможность создания проблемно-ориентирован- 
ных расширений системы МПРОЛОГ, например, та- 
ких как система Т-ПРОЛОГ, реализованная на языке 
МПРОЛОГ, которая предназначена для решения задач 
моделирования систем с дискретными событиями. 

4. Где используется язык МПРОЛОГ ? 

Первый интерпретатор языка Пролог был создан в 
1972 г. в Марселе. В 70-е годы Прологом интересовал- 
ся очень узкий круг специалистов, главным образом из 
академических и университетских кругов. 

В конце 70-х годов язык Пролог был выбран в ка- 
честве языка-ядра в японском Проекте компьютеров 
пятого поколения. Этот факт, а также широкое разви- 
тие работ в области искусственного интеллекта, в 
частности по созданию экспертных систем, в значи- 
тельной степени способствовало росту популярности 
языка и его активному использованию. 

В 80-е годы Пролог стали широко использовать для 
решения широкого круга прикладных задач в самых 
разнообразных областях. Во второй половине 80-х го- 
дов началось использование языка Пролог в ведущих 
научно-исследовательских организациях СССР. 

В настоящее время система МПРОЛОГ в СССР ис- 
пользуется более чем в 170 организациях. География 
использования системы МПРОЛОГ насчитывает свыше 
70 городов. Система МПРОЛОГ распространяется как 
коммерческий продукі более чем в 10 странах мира, 
включая США, Японию, ФРГ, Канаду и т.д. К настоя- 
щему времени продано несколько тысяч экземпляров 
системы. 

Использование системы МПРОЛОГ наиболее эф- 
фективно в тех прикладных областях, в которых тре- 
буется: 

1) Создание экспертных систем. 

МПРОЛОГ является “естественным 44 языком для со- 
здания экспертных систем. Знания эксперта в кон- 
кретной области могут быть очень эффективно пред- 
ставлены в виде Пролог- программы. Основная работа 
экспертной системы состоит в выполнении логического 
вывода на основании фактов и правил, относящихся к 
области данной задачи. 

2) Получение ответов на вопросы с помощью логи- 
ческого вывода (автоматическое доказательство тео- 
рем, синтез и верификация программ, вопросно-ответ- 
ные системы и т.п.). 

3) Выполнение символьных вычислений ( напри- 
мер, обработка текстов естественного языка). Возмож- 
ности символьных вычислений в языке МПРОЛОГ со- 
поставимы с соответствующими возможностями языка 
Лисп, а в сочетании с другими средствами языка 
МПРОЛОГ — даже и превосходят их. 

4) Поиск в базе данных, содержащей не только 
факты, но и правила, формулирующие законы о взаи- 


моотношениях и взаимозависимости этих фактов. Ти- 
пичная ситуация, подходящая для применения языка 
МПРОЛОГ — это наличие некоторого набора условий, 
которым должен удовлетворять объект. 

Программу на языке МПРОЛОГ с некоторыми до- 
пущениями можно рассматривать как реляционную 
базу данных, которая содержит отношения, выражаю- 
щие факты и правила, и позволяет делать запросы и 
добавлять новую информацию в базу данных. Утверж- 
дение может быть просто добавлено как новое правило 
языка МПРОЛОГ. К реляционной базе данных (т.е. к 
программе) допустимы самые разнообразные запросы, 
но такие, ответ на которые может быть логически вы- 
веден системой МПРОЛОГ из содержимого базы дан- 
ных. 

При организации хранения информации не надо 
придерживаться какой-нибудь заранее принятой схе- 
мы. Это относится только к той части базы данных,' 
которая находится в оперативной памяти компьютера 
и непосредственно обрабатывается программой на язы- 
ке МПРОЛОГ. Когда надо обрабатывать большие объе- 
мы данных, система МПРОЛОГ должна быть подходя- 
щим образом связана с системой управления базой 
данных ( СУБД ). 

5) Конструирование объектов, удовлетворяющих оп- 
ределенному набору условий ( автоматизированное 
проектирование в области архитектуры, химии, мик- 
роэлектроники и т.п.). 

6) Имитация реальных ситуаций, включающих па- 
раллельные процессы, определенные непроцедурным 
способом, т.е. моделирование высокого уровня, когда 
свойства модели можно описать утверждениями на 
языке МПРОЛОГ. 

7) Быстрая разработка на МПРОЛОГе небольших 
по объему прототипов больших и сложных систем в 
процессе создания последних, например, в тех случа- 
ях, когда важно за короткое время перейти от специ- 
фикации задачи к работающей программе. 

5. Пример элементарной программы 
на языке МПРОЛОГ 

Рассмотрим простейшую программу на языке 
МПРОЛОГ. Программа содержит информацию о род- 
ственных отношениях в семье. 

Программа состоит из одного модуля по имени “се- 
мья 44 , в котором находятся восемь фактов, три правила 
и комментарии. Факты содержат информацию о род- 
ственных отношениях в семье. Пояснения к тексту 
программы оформлены в виде комментариев на языке 
МПРОЛОГ. Ниже приведен текст программы. 

тосіиіе семья. — Заголовок модуля по имени семья. 

/* Пример программы на языке МПРОЛОГ*/ 

/*$еіесі*/ — Служебное слово, сообщающее 

претранслятору о необходимости начать 
новую страницу в листинге при претрансляции 
Ьо(1у. — Начало тела модуля 

/* Комментарий к определению “отец 44 */ 
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/* Информация об отцах : •/ 

/* Факты вида м отец(Х,Ѵ) м означают, •/ 

/* что X является отцом V */ 

/* Обратите внимание, что собственные имена V 
/* пишутся с маленькой •/ 

/* буквы. V 


отец(иван, федор) . 
отец(иван, Николай) . 
отец(иван, максим) . 
отец (федор, Виктор) . 
отец (федор, Степан) . 
отец(николай, сидор) . 

епсітосі /* семья •/• — Признак конца модуля 

К приведенной выше программе можно обратиться 
с различными вопросами (запросами). 

Примечание . 

Если у Вас есть возможность работать с 
системой АШРОЛОГ, то рекомендуем Вам в 
процессе чтения настоящей статьи выпол- 
нять примеры программ на компьютере . 

Зададим программе вопрос, является ли Иван отцом 
Федора: 

?отец(иван,федор) . 

Интерпретатор сопоставит полученный вопрос с 
имеющимися в программе фактами (т.е. с содержи- 
мым внутренней базы данных). 

Сопоставление закончится успешно, т.к. вопрос в 
точности совпал с одним из фактов программы. 

На экран будет выдан ответ “Ѵе5“ (да), и вопрос о 
необходимости продолжения поиска новых вариантов 
решений: 

Сопііпие (у/п) ? (Продолжить ли (да/нет) ?) 

Ответим системе “п“, т.к. мы знаем, что в програм- 
ме содержится всего один 'подходящий факт, следова- 
тельно, поиск других вариантов решений не имеет 
смысла (в виду их отсутствия). 

Зададим программе вопрос, является ли Иван отцом 
Виктора: 

?отец(иван, Виктор) . 

Программа даст отрицательный ответ “N0“ (нет), 
т.к. Иван не является отцом Виктора. 

Зададим программе вопрос, является ли Михаил от- 
цом Василия: 

?отец(михаил, Василий) . 

Программа даст такой же отрицательный ответ 
“N0“, но в этот ответ вложен скорее смысл “не из- 
вестно“ или “нет данных 44 , т.к. в нашей программе 
нет информации о родственных отношениях Михаила 
и Василия. 

В двух последних случаях мы получили одинаковые 
ответы “N0“. Но между этими двумя, внешне одина- 
ковыми ответами, имеется большое содержательное 
отличие. В первом случае полученный ответ может 
трактоваться как отрицательный ответ “нет“,т.е. ука- 
занные в нашей базе данных Иван и Виктор не явля- 


ются отцом и сыном, т.е. содержание запроса противо- 
речит содержанию базы данных программы, а во вто- 
ром случае ответ может трактоваться как “не извест- 
но 44 , “нет данных 44 , “не знаю 44 и т.п., потому что у 
программы просто нет данных, не хватает информа- 
ции для того, чтобы дать правильный ответ на поста- 
вленный вопрос. 

Теперь рассмотрим вопросы, в которых используют- 
ся переменные. Переменные в языке МПРОЛОГ могут 
начинаться с прописной латинской буквы или с сим- 
вола подчеркивания. 

Определим, чьим отцом является Иван, обозначив 
переменную прописной латинской буквой, и задав 
программе вопрос : 

?отец(иван,Х). 

Программа ответит: X = федор и предложит продол- 
жить поиск других возможных решений, задав нам 
вопрос: Сопііпие (у/п)?. 

Если мы будем каждый раз отвечать у (т.е. “да 44 ), 
то программа найдет все возможные варианты реше- 
ний: 

X = Николай, X = максим. 

Этот вопрос можно представить и по-другому, ис- 
пользуя второй вариант обозначения переменных, с 
помощью знака подчеркивания. Тогда переменные мо- 
гут быть представлены в более наглядной форме, на- 
пример, в виде “_сын_ивана“. 

?отец(иван,_сын_ивана) . 

Программа ответит: сын_ивана = федор и, как и в 
предыдущем случае, запросит нас о том, надо ли про- 
должить поиск других ответов: Сопііпие (у/п)? 

Ответив “у“ или просто нажав клавишу ввода 
«Епіег», мы получим следующий вариант ответа: 
сын_ивана = Николай. Поиск и вывод на экран новых 
ответов будет продолжаться до тех пор, пока не исчер- 
паются все подходящие данные (факты), имеющиеся в 
базе данных программы. Если мы ответим “п“, то 
программа прекратит дальнейший поиск вариантов от- 
ветов. 

В случае, если в программе присутствует несколько 
одинаковых имен, программа будет их находить и вы- 
водить на экран столько раз, сколько раз они встреча- 
ются в программе. 

Например, рассмотрим случай, когда в семье дед, 
отец, внук и правнук имеют одинаковые имена, 
отец (иван, иван). 
отец(иван,иван). 
отец (иван, иван). 

В ответ на запрос 
?отец(иван,Х). 

мы можем трижды получить один и тот же ответ: 
X = иван. 

Точнее говоря, мы получим три одинаковых ответа, 
обозначающих отца, внука и правнука соответственно. 

Найдем имеющиеся в базе данных пары “отец- 
сын 44 , задав вопрос: 

?отец(Х,Ѵ). 

или, что более наглядно: 

?отец(_отец,_сын) . 
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В первом случае программа ответит: 

X = иван 
V = федор 
Во втором: 
отец = иван 
сын = федор 

и запросит о необходимости продолжения поиска дру- 
гих вариантов ответов: Сопііпие (у/п)? 

Отвечая “у“, или просто нажимая клавишу ввода 
«Епіег», мы получим все возможные варианты отве- 
тов, т.е. все имеющиеся в базе данных программы па- 
ры “отец-сын“. 

Теперь рассмотрим на языке МПРОЛОГ правило, 
определяющее, что значит быть братом: два человека 
являются братьями, если имеют общего отца. На язы- 
ке МПРОЛОГ это утверждение может быть представ- 
лено следующим образом: 
брат(Х.Ѵ) :- 

отец(2,Х), отец(2,Ѵ). 

Это правило обладает одним существенным недо- 
статком — с его помощью будут найдены люди, сами 
себе являющиеся братьями. 

Введем условие, отсекающее подобные решения, 
т.е. условие типа “сам себе не брат“ (по! Х = Ѵ), тогда 
правило будет иметь вид: 
брат(Х,Ѵ) :- 

отец (2, X), отец (2, V), поі X = У. 

Определим с помощью этого правила, являются ли 
братьями Федор и Николай, Федор и Сидор. Для этого 
зададим системе следующие вопросы : 

?брат (федор, Николай) . 

?брат(федор,сидор) . 

Затем определим братьев Федора: 

?брат (федор, братфедора) . 

Определим все пары братьев: 

?брат(Х,Ѵ). 

Теперь найдем человека, имеющего брата. Причем, 
нас интересует только человек, имеющий брата. Имя 
брата нас не интересует. В этом случае для обозначе- 
ния имени брата можно использовать безымянную пе- 
ременную, обозначаемую символом подчеркивания. 
Запрос будет иметь вид: 

?брат(Х,_). 

Рассмотрим правило, определяющее, что значит 
быть дедом: дед — это отец отца. 
дед(Х,Ѵ) :- 

отец(Х,2), отец (2, V). 

Рассмотрим другие, более сложные правила, опре- 
деляющие, что значит быть дедом: дед — это отец от- 
ца или отец матери. Такое определение состоит уже 
из двух предложений, первое из которых определяет 
деда по отцу, а второе — деда по матери. 
дед(Х,Ѵ) 

отец(Х,2), отец(2,Ѵ). 
дед(Х,Ѵ) 

отец(Х,2), мать(2,Ѵ). 

Это определение можно записать короче, в виде од- 


ного предложения, если использовать логическую связ- 
ку “или“, обозначаемую в языке МПРОЛОГ точкой с 
запятой “ ; Тогда правило, определяющее деда, бу- 
дет выглядеть следующим образом: 
дед(Х,Ѵ) :- 

отец(Х,2), отец(2,Ѵ) ; 
отец (X, 2), мать (2, V). 

Запись может быть сделана еще короче, если ис- 
пользовать скобки: 
дед(Х,Ѵ) :- 

отец (X, 2), ( отец (2, V) ; мать(2,Ѵ) ). 

С помощью этого правила определим, чьим дедом 
является Иван. Определим всех внуков Ивана. Рас- 
смотрим правило, определяющее что значит быть ро- 
дителем: родитель — это отец или мать, 
родитель (Х,Ѵ) :- 
отец(Х,Ѵ); 
мать(Х,Ѵ). 

Определим родителей Федора и Виктора: 
?родитель(Х, федор). После введения правила, определя- 
ющего родителя, правило, определяющее деда, форму- 
лируется так : дед — это отец родителя: 
дед(Х.Ѵ) :- 

отец(Х,2), родитель (2, V). 

Программу можно усложнить еще, добавив в ка- 
честве аргументов, например, год рождения. Програм- 
ма будет иметь следующий вид: 
отец (иван, 1 925, Николай, 1 960) . 
отец(иван, 1 925, Константин, 1 970) . 
отец (иван, 1 925, федор, 1 980) . 

Тогда в запрос можно включать год рождения, на- 
пример: найти сыновей Ивана, родившихся до 1965 
года : 

?отец(иван,_,Х,Ѵ) ,Ѵ«1 965. 

И наконец, введем правило, определяющее, что зна- 
чит быть сыном своих родителей: 

сын(Х,Ѵ,2) — будет означать, что X является сы- 
ном своего отца V и матери 2. Тогда правило имеет 
вид: 

сын(Х,Ѵ,2):- 

отец(Ѵ,Х),мать(2,Х). 

С помощью этого правила мы можем определить, 
например, сына Ивана и Марии, задав вопрос: 

?сын(Х, иван, мэрия). 

Аналогично можно определить, кто является сыном 
Анастасии, причем, кто является отцом, нас не инте- 
ресует, поэтому для обозначения отца используем бе- 
зымянную переменную : 

?сын (Х,_,анастасия) . 

Аналогично можно определить имя сына, не инте- 
ресуясь именами его родителей. Обозначим имена ро-~ 
дителей безымянными переменными, тогда вопрос бу- 
дет иметь следующий вид : 

?сын(Х,_,_). 

В дальнейшем мы рассмотрим более сложные при- 
меры программ на языке МПРОЛОГ. 

И в заключение, хотелось бы предложить ответы 
еще на три вопроса. 
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6. На каком языке реализована 
система МПРОЛОГ? 

Система МПРОЛОГ реализована частично на ас- 
семблере, частично на самом языке МПРОЛОГ, час- 
тично на языке описания компиляторов СОЬ-2. 

7. Кто является официальным 
дистрибьютором системы МПРОЛОГ? 

Система МПРОЛОГ официально распространяется 
на территории СССР Институтом проблем информа- 
тики Академии Наук СССР через малое предприятие 
“Информатика 4 *, учредителем которого является ИПИ 
АН СССР. 

Система МПРОЛОГ распространяется для следую- 
щих ЭВМ и операционных систем (табл.1). 


Таблица 1 


Тип ЭВМ 

Операционная система 

ІВМ РС 

М5 Э05, РС 005 

ЕС 

СВМ/ПДО, ѴМ/СМ5 

ѴАХ 

ИНМОС, МОС ВП 
ІЖІХ, ѴМ5 


8. Как получить систему МПРОЛОГ ? 

Заявки на получение системы МПРОЛОГ с указа- 
нием вида ЭВМ и операционной системы необходимо 
направлять в малое предприятие “Информатика 44 по 
адресу: 

117900, Москва, ГСП-1, В-334, ул. Вавилова, 

дом 30/6, ИПИ АН СССР, МП “Информатика 44 . 

Справки по тел.: ( 095 ) 362-46-54. 

Факс: (095) 310-70-50. Телекс 411853 ^РО 511. 
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Фирма-производитель жестких дисков Місгороііз 
начала выпуск дисков, предназначенных для 
высокопроизводительных персональных компьюте- 
ров. В контроллерах дисков использованы алгорит- 
мы кэширования, подобные применяемым на супер- 
компьютерах, которые позволяют уменьшить 
среднее время доступа до 3.9 миллисекунд. Такая 
скорость доступа была достигнута при 
использовании встроенной кэш-памяти объемом 
от 64 до 256 Кбайт, в зависимости от емкости 
диска. 

Місгороііз планирует также выход на рынок 
дисковых массивов с технологией, использующей 
уже имеющиеся дисковые контроллеры на базе 386 
и 486 процессоров для выработки контрольного 
разряда, обеспечивающего проверку и 
восстановление целостности данных. 

Еіесігопіс Еп&пеегіпя Тітез, 
ЫоѵетЪег 5, 1990, 

Во втором квартале 1991 года объемы продажи 
компьютеров МасіпіозН фирмы Арріе выросли на 85 
% по сравнению с аналогичным периодом прошло- 
го года. Прибыли компании выросли на 19%, а ди- 
виденды по акциям — на 3%. 

За предыдущий квартал, окончившийся 21 марта 
1991 года, фирма продала компьютеров на 1598 


миллиарда долл. Все больше и больше машин 
(52%) реализуется за пределами США. 

“Возрастающий спрос на новые недорогие модели 
вызвал новый период подъема компании как на 
американском, так и на международном рын- 
ках 44 , — сказал президент фирмы Джон Скали. 

Ые\ѵзЪу1е8 Ые\ѵ8 ЫеЫюгк, Лргіі 15 , 1991, 

На выставке Сотіек'91 в Москве фирма Затзип^ 
впервые представила свою новую марку для СССР 
и Восточной Европы — Зупігопіх. Под этой маркой 
будут продаваться сделанные в США компьютеры 
на базе І286 и І386, факсы, телевизоры, видеокаме- 
ры и телефоны. 

Компьютеры будут поставляться с прошитой ки- 
риллицей в видеоадаптерах и стандартными русско- 
латинскими клавиатурами. 

Что еще нужно для советского рынка? Надеж- 
ность! Один из компьютеров (вероятно, специально 
подготовленный, но тем не менее) проработал неде- 
лю на выставке в наполненном водой аквариуме. 

Фирма СотриІегГапсІ, имеющая сейчас магазин в 
Москве и филиалы в Киеве и Ленинграде, первой 
подписала контракт на продажу этих машин в 
СССР. 

ЫемзЬуІез ЫеЬѵогк, Лргіі 75, 1991, 
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ПАРАД СУБД ПРОДОЛЖАЕТСЯ... 


П арад СУБД завершен. Но... парад продолжается. Если вы 
захотите узнать о других программных продуктах, 
предназначенных для управления базами данных, пишите нам, 
мы с удовольствием ответим. 


Парад СУБД 
продолжается... 


Фирма Огасіе 
Программа Огасіе 5.1.Ъ 

Системные требования 

Программа Огасіе функционирует на компьютерах 
с процессором 80286 или 80386, имеющих не менее 
640 Кбайтов оперативной памяти и 2.5 Мбайта расши- 
ренной памяти, один дисковод, 10 Мбайтов памяти на 
жестком диске и операционную систему 005 версии 
2.1 и выше. 

Характеристика программы 

Появление операционной системы 05/2 и стан- 
дартного встроенного ШЧІХ для РС вызвало повышен- 
ный интерес к программам, разработанным для гете- 
рогенных распределенных систем. В области баз дан- 
ных этот интерес выразился во включении новых 
функций, обеспечивающих многозадачность, поддерж- 
ку языка 5(2Ь и совместимость с базами данных уни- 
версальных компьютеров. Огасіе, несмотря на высокую 
сложность освоения этого пакета, содержит в себе все 
необходимое для работы в распределенных системах. 

Вследствие высокой мощности пакета и его прото- 
типов, работающих на универсальных компьютерах, 
Огасіе зарекомендовал себя превосходным средством 
разработки больших баз данных, особенно в тех случа- 
ях, когда микрокомпьютеры составляют лишь часть 
вычислительных мощностей организации. 

Что касается конкуренции, то Огасіе испытывает ее 
прежде всего со стороны пакетов, также функциони- 
рующих на многих платформах, и прежде всего РС 
Росиз, Іп^гез и ІпГогшіх. Совместные разработки, веду- 
щиеся Оі^ііаі Едиіртепі, Кеіаііопаі ТесЬпоІо^у, 
АзМоп-ТаІе и Сиііеі, в части, касающейся создания 
совместимой с 5(2Ь базы данных К.с1Ь для операцион- 
ной системы ѴАХ/ѴМ5, также могут иметь серьезные 
последствия для Огасіе, занимающего сейчас весьма 
значительную долю рынка СУБД для ѴАХ. Наконец, 
сервер 5(}Ь фирм АзМоп-Таіе, МісгозоН и 5уЬазе дол- 


/ 

жен обеспечить интерфейс с базами данных в локаль- 
ных сетях. 

Огасіе является модульной системой, а каждый мо- 
дуль представляет собой отдельную программу со сво- 
ими характеристиками и требованиями. Это наклады- 
вает свой отпечаток и на пользовательский интерфейс. 
Практически в каждом из шести модулей Огасіе со- 
бственный интерфейс, а из меню одного модуля невоз- 
можно обратиться к другому. Назначение функцио- 
нальных клавиш в разных модулях также отличается. 
Некоторые модули Огасіе имеют систему меню (к ним 
относятся 5рЬ*КероИ\ѴгіІег, 5(}Ь*Рогт5, 5(}Ь*Са1с), 
другие работают лишь в командном режиме 
(5(}І.*Р1и5). 

Проектирование базы данных в Огасіе возможно 
двумя способами. В 5(}Ь*Рогт5 создание базы данных 
осуществляется по системе подсказок, в 5()Ь*Р1и5 ис- 
пользуется команда сгеаіе ІаЫе. 

При проектировании форм документов в Огасіе ис- 
пользуется меню-ориетированная программа 
5(}Ь*КерогІ\Ѵгііег. Модуль на каждом из этапов ввода 
высвечивает на экране соответствующие подсказки. 
Одновременно с формированием отчета КерогіѴѴгіІег 
формирует соответствующие операторы 5(}Ь. Модуль 
позволяет создавать отчеты в широком диапазоне, на- 
чиная с простых бланков, определяемых по умолча- 
нию, и заканчивая пользовательскими отчетами, име- 
ющими колонтитулы и другие сложные элементы. 

Модуль 5(ЗЬ*Рогт5 предоставляет меню-ориентиро- 
ванный оконный интерфейс для создания экранных 
форм базы данных. Меню отражает практически все 
возможные варианты создания баз данных. Единствен- 
ное исключение составляют индексы, которые опреде- 
ляются модулем 5(}Ь*Р1и5 после создания таблицы. 

Вводить данные можно либо с помощью команды 
іпзегі в 5(2Ь*Р1 іі 5, либо в 5рЦ*Рогт5. 

Запросы в Огасіе также обрабатываются двумя раз- 
личными способами. 5(}Ь*Р1и5 поддерживает стандарт- 
ный язык запросов 5(2Ь, а 5(2Ь*Рогт5 имеет функцию 


КомпьютерПресс 5'91 





БАЗЫ ДАННЫХ 


51 


(}иегу-Ву-Рогт5, когда запрос формируется в шаблоне 
с указанием имен и логических операций. 

Огасіе имеет чрезвычайно мощные реляционные 
средства и средства программирования. Размер и 
сложность базы данных в большинстве своем ограни- 
чены только возможностями операционной системы и 
объемами доступной памяти. Огасіе поддерживает свя- 
зи между записями типа “один-ко-многим“, “многие- 
к-одному“, “многие-ко-многим“. Мощные поисковые 
средства позволяют задавать альтернативные крите- 
рии, включать в условия поиска отрицание и диапазо- 
ны значений. 

Огасіе позволяет динамически изменять структуру 
базы данных. 

5(}Ь Огасіе обеспечивает полную совместимость с 
языками 1ВМ ЗС^Ь/ЭЗ и ОВ/2. 

Структура данных 

Число таблиц, с которыми может одновременно ра- 
ботать Огасіе» не ограничено. Файл может включать 
до 255 полей, но не более 64.000 байтов в записи. 
Огасіе 5.1.Ь поддерживает символьные, текстовые 
(длиной до 64 Кбайтов), числовые и долларовые дан- 
ные, а также форматы даты и времени. С помощью 
триггеров можно определить данные типа “да/нет“ и 
константы. 

Несмотря на то, что Огасіе имеет широкие возмож- 
ности экспорта и импорта файлов в форматах баз дан- 
ных больших машин, он не поддерживает ни одного 
из форматов РС. 

Защита данных 

Огасіе обладает, пожалуй, наиболее мощными сред- 
ствами защиты данных из числа рассматриваемых. 
Программа имеет множество уровней регистрации и 
защиты данных в системе. Полномочия доступа к дан- 
ным каждого из пользователей определяются только 
администратором базы данных. 

Дополнительная информация 

Однопользовательская версия Огасіе РгоГеззіопаІ 
5.1.5 для 005 стоит 1299 долл. Продаются и версии 
для работы в локальной сети. 

Предоставляются бесплатные телефонные консуль- 
тации в течение 30-дневного гарантийного срока. За- 
ключаются договоры на сопровождение. Полное сопро- 
вождение, включающее предоставление новых версий 
й телефонные консультации, стоит 499 долл, в год. В 
случае только предоставления новых версий сопровож- 
дение обойдется в 299 долл, в год. 

Фирма ЗутаШес 
Программа <3&А версия 3.0 

Системные требования 

Программа <3&А работает на компьютерах ІВМ 
РС/ХТ/АТ и Р5/2 с оперативной памятью 512 Кбайт 
и операционной системой МЗ-ЭОЗ версии 2.0 и выше. 
Для работы с ()&А в локальной сети требуется 


640 Кбайтов оперативной памяти и МЗ-ООЗ версии 
4.0. 

Характеристика программы 

(2&А сочетает в себе возможности базы данных и 
текстового процессора. Она имеет также элементы ис- 
кусственного интеллекта, позволяющие формулировать 
запросы на естественном (английском) языке. Про- 
грамма значительно более мощна по сравнению с дру- 
гими системами для обработки плоских файлов. В 
частности, имеются реляционные средства создания 
форм отчетов на основе нескольких файлов. Уровень 
возможностей (}&А позволяет отнести ее, наряду с 
КарібРіІе фирмы АзНІоп-ТаІе, КеПех фирмы Вогіапб и 
РРЗ:РгоГе55іопа1 РПе фирмы 5оН\ѵаге РиЫізНіп^, к ка- 
тегории простых программ обработки данных. Этот 
тип программ разработан для категории пользователей 
с потребностями, меньшими, чем у работающих, на- 
пример, с (1ВА5Е. 

Программа имеет систему меню, разработанную по 
аналогии с интерфейсом интегрированного семейства 
программ РР5. 

(}<&А включает пять интегрированных модулей: РПе, 
Керогі, \УгНе, Іпіеііі^епі Аззізіапі и ШіШіез. Послед- 
ний содержит опции для задания типа принтера, эк- 
спорта-импорта данных и выполнения из программы 
функций 005. 

Іпіеііі^епі Аззізіапі поставляется вместе со встроен- 
ным словарем, содержащим около 400 слов, объем 
словаря можно увеличивать. Программа позволяет 
формулировать запросы в виде предложений на анг- 
лийском языке. 

Текстовый процессор (}&А имеет практически все 
необходимые средства, включая проверку орфографии, 
математические функции, шрифты и клавишные мак- 
рокоманды. 

Создание базы данных, добавление и поиск данных 
в (2&А выполняется в меню РПе, при этом каждое 
действие сопровождается соответствующей подсказкой. 

Средства программирования (}&А достаточно мощ- 
ны для подобного рода системы. Допускается устанав- 
ливать значения полей, принимаемые по умолчанию, 
а также ограничивать их верхний и нижний пределы. 

Помимо Іпіеііі^епі Аззізіапі, (}&А включает тради- 
ционные средства поиска по методу (}иегу-Ьу-Рогт. 
Имеются система шаблонов и средства поиска подоб- 
ных слов. 

В ( З&А имеется команда ХЬоокир, позволяющая со- 
здавать представления, содержащие поля нескольких 
файлов. 

Генерация стандартных отчетов в (}<&А не создает 
особых сложностей, однако включение дополнитель- 
ных элементов требует использования кодов формати- 
рования, что вызывает определенные сложности. 

Существенным достоинством (}<&А является много- 
пользовательский режим работы. Синхронизация до- 
ступа обеспечивается путем блокировки записи первой 
поступившей на выполнение транзакции. Запись бло- 
кируется вплоть до выполнения запроса. 
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Структура данных 

Поскольку (2&А не является полностью реляцион- 
ной СУБД, она может одновременно работать только с 
одним файлом, однако, как отмечалось выше, имеются 
средства для создания представлений. Файл может 
включать до 2180 полей и иметь длину записи не бо- 
лее 64 Кбайтов. (}&А поддерживает 7 типов полей — 
текстовые (длиной не более 1638 байтов), числовые, 
долларовые, ключевые, логические, даты и времени. 

В зависимости от длины полей допускается сорти- 
ровка файла с вложенностью до 512 уровней. Кроме 
того, (}&А позволяет индексировать данные, число ин- 
дексируемых полей в файле не превышает 115. Отме- 
тим, что другие аналогичные программы не имеют 
средств индексирования. 

(2&А может импортировать файлы в форматах 01 Р, 
А5СІІ, Ьоіиз 1-2-3, ІВМ Ріііп^ Аззізіапі и 6ВА8Е 
ІІ/ІІІ. Экспортировать файлы можно в формат ОІР, 
А5СІІ переменной и фиксированной длины и 6ВА$Е 
ІІ/ІІІ. 

Защита данных 

(}&А, в отличие от большинства программ подобно- 
го класса, имеет средства защиты данных. Уровни до- 


ступа устанавливаются администратором системы в 
экране Ассезз Сопігоі Зсгееп. 

Дополнительная информация 
Цена версии 3.0 <3&А составляет 349 долл. 5-дюй- 
мовые дискеты могут быть бесплатно заменены на 
3-дюймовые, а дискеты для 005 на дискеты для 
05/2. Замена дефектных дискет осуществляется бесп- 
латно в течение 90-дневного гарантийного срока. Се- 
тевое обеспечение (}&А Ыейѵогк Раск стоит 299 долл. 
Этот пакет приобретается для каждых трех поль- 
зователей. Зарегистрированные пользователи приобре- 
тают право на бесплатную подписку на ежеквар- 
тально издаваемый журнал и бесплатные телефонные 
консультации. 

М. Михайлов 

По материалам: 

Н.ЕбеЫеіп, “Ап иргіаіе оп геіаііопаі ТесНпоІо^у 44 , 
ЭаІаВазесі Асіѵізог, Липе, 1990. 

Оаіарго Керогіз оп Місгосотриіегз. Эаіа Мападетепі. 
С.ЗсЬиззеІ, “ТНе ІВМ ЕКесІ“, ОаІаВазесІ Абѵізог, 
МагсН, 1990. 



МАЛОЕ ПРЕДПРИЯТИЕ 
“ИНФОРМАТИКА” 

Учредитель - институт проблем 
информатики Академии Наук СССР 

ТМООП - ТЕХНОЛОГИЧЕСКИЙ МОДУЛЬ ОБЪЕКТНО- 
ОРИЕНТИРОВАННОГО ПРОГРАММИРОВАНИЯ 

■ быстрое и эффективное создание прототипов программ 

■ решение задач из области искусственного интеллекта 

■ обучение технологии объектно-ориентированного программирования 

■ описание решаемой задачи в терминах объектов, взаимодействующих между собой 

■ русскоязычный аналог ЗтаШаІк 

■ многооконный интерфейс с пользователем 

■ иерархическая система меню 

■ литература: 

Иванов А. Г., Карпова А.В., Семик В.П., Филинов Ю.Е. Объектно-ориентированная среда 
программирования. В сб. трудов ИПИ АН СССР. Вып. 2. М.: Наука, 1990. 

Тематический выпуск по объектно-ориентированному программированию, Программирование, № 6, 1990. 


117900, Москва, ГСП-1, В-334, ул. Вавилова 30/6, ИПИ АН СССР, Малое 

предприятие “Информатика”. 

Телефон: (095) -362-46-54, Факс: <095)-310-70-50. Телекс: 411853 ШРО 80 
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ОПЫТ РАЗРАБОТКИ 
СПЕЦИАЛИЗИРОВАННЫХ 


БАЗ ДАННЫХ 


Одним из основных направлений использования 
персональных ЭВМ является создание систем, осно- 
ванных на применении разнообразных баз данных. Ес- 
тественно, что в качестве инструментальных средств 
при этом используются в первую очередь системы уп- 
равления базами данных, из которых сегодня наиболее 
популярны 6ВА5Е, РохВАЗЕ, Сііррег. 

По такому пути пошли и мы, когда приступили к 
разработке специализированных систем накопления и 
обработки инженерно-геологических и гидрогеологи- 
ческих данных (базы фактографических данных). Ис- 
пользование языка РохВАЗЕ позволило нам в мини- 
мальные сроки решить задачу первого этапа разработ- 
ки — накопления данных: ввод, коррекцию, хранение, 
вывод информации. 

Следует отметить, что проблема накопления данных 
имеет самостоятельную ценность для заказчика (а 
иногда и просто все его проблемы на этом заканчива- 
ются). Поэтому важной задачей для нас являлась ми- 
нимизация сроков разработки и внедрения данного ва- 
рианта системы. В связи с этим при выборе конкрет- 
ного инструмента разработки мы учитывали не только 
соответствие конкретного языка решаемой задаче, но 
и подготовленность специалистов-разработчиков. Так, 
при выборе РохВАЗЕ мы исходили из того, что у нас 
накоплен значительный опыт разработки систем авто- 
матизации бухгалтерского учета. 

Однако в ходе дальнейшей работы по развитию си- 
стемы стало очевидно, что в рамках только РохВАЗЕ 
ее выполнить нельзя. Прежде всего этс? касалось обра- 
ботки данных. Для их решения требуется активно ис- 
пользовать графические средства отображения и ввода 


данных, которые в стандартных СУБД практически 
отсутствуют. Кроме того, многие алгоритмы обработки 
(в частности, статистика, специальные системы обра- 
ботки гидрогеологических данных) уже были реализо- 
ваны ранее на других языках и перевод их на язык 
СУБД был нецелесообразен. 

Второй проблемой явилась необходимость модульно- 
го построения системы. В частности, увеличение 
функциональных возможностей системы привело к 
резкому росту объема используемой оперативной па- 
мяти. Естественный шаг при решении этой проблемы 
— выделение подсистемы накопления и обработки 
данных в различные модули. В рамках РохВАЗЕ со- 
здание такой модульной системы представляет опреде- 
ленные трудности. 

С учетом этих аспектов было решено обрабатываю- 
щие программы писать в виде автономных модулей на 
языке (ЗиіскВАЗІС, который принят нами в качестве 
основного многофункционального инструментального 
средства разработки. 

Таким образом, на данном этапе работы нами была 
принята двухуровневая организация системы: подсис- 
тема накопления данных, реализованная на РохВАЗЕ, 
и подсистема обработки на (ЗиіскВАЗІС. Однако реа- 
лизация такой системы потребовала обеспечения до- 
ступа к файлам базы данных со стороны обрабатываю- 
щих программ. 

Традиционным решением этой задачи является ор- 
ганизация обмена с файлами базы данных средствами 
СУБД, при этом взаимодействие с обрабатывающими 
программами производится через символьные последо- 
вательные данные (импорт исходных данных и эк- 
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спорт результатов обработки). Основной вариант схе- 
мы взаимодействия модулей системы выглядит следую- 
щим образом (рис. 1): 

1. Головной модуль системы разрабатывается на 
РохВАЗЕ. В нем находится главное меню системы, из 
которого можно попасть в головной раздел обработки 
данных, реализованный в рамках данного модуля. 

2. Головной раздел обработки включает меню вы- 
полняемых операций, в соответствии с которыми про- 
изводится чтение исходных данных из базы данных, 
их импорт в последовательный файл, запуск соответ- 
ствующего обрабатывающего модуля, экспорт резуль- 
татов и запись их в базу данных. 

3. Обрабатывающий модуль (или набор модулей) 
реализуется на любом языке программирования. Об- 
мен данными с базой данных (чтение исходной ин- 
формации и вывод результатов, которые должны быть 
записаны в базу) производится через временные, со- 
здаваемые для выполнения конкретного вида обработ- 
ки, последовательные файлы импорта-экспорта. 


Достоинством такой структуры системы является 
независимость обрабатывающих модулей от организа- 
ции самой базы данных. Вместе с тем, она обладает 
следующими серьезными недостатками: 

1. Так как обрабатывающие программы работают 
под управлением головного модуля, все они должны 
находиться в оперативной памяти одновременно. Со- 
ответственно под обрабатывающие программы может 


быть отведен весьма ограниченный объем памяти. На- 
пример, при работе с РохВАЗЕ реальный объем опера- 
тивной памяти под модули обработки может состав- 
лять не более 100-150 Кбайт. Даже с учетом возмож- 
ного разбиения подсистемы обработки на отдельные 
модули этого явно недостаточно (особенно, если иметь 
в виду достаточно высокие требования к оперативной 
памяти для программ графической обработки данных). 

2. Перед запуском соответствующего обрабатываю- 
щего модуля весь объем необходимых исходных дан- 
ных должен быть определен заранее. Получение до- 
полнительных данных, потребность в которых возник- 
ла уже в ходе обработки, в данном варианте системы 
неосуществимо. 

Возможен и другой вариант организации системы, 
при котором обрабатывающий модуль является голов- 
ным. По мере поступления запросов на обработку дан- 
ных он обращается к специальному модулю обмена с 
базой данных, реализованному в среде соответствую- 
щей СУБД, для ввода-вывода данных через файлы им- 
порта-экспорта. Однако, наряду с 
присущими первому варианту недо- 
статками, в данном случае еще и 
время обмена данными будет весьма 
значительным (требуется двойная 
загрузка модуля обмена данными — 
для импорта и экспорта, причем за- 
грузка системы РохВАЗЕ сама по 
себе занимает несколько секунд). 

Принципиально другой подход к 
реализации системы открывает воз- 
можность автономного доступа к ба- 
зе данных со стороны различных 
модулей системы (рис.2.). В этом 
случае достаточно просто решаются 
многие проблемы — и технические 
и организационные. 

Во-первых, при этом практически 
снимаются ограничения на объем 
оперативной памяти для модулей 
системы, значительно сокращается 
время запуска отдельных операций 
и снижается нагрузка на диск (нет 
необходимости в создании времен- 
ных файлов на диске). 

Во-вторых, подсистемы накопле- 
ния и обработки данных могут раз- 
рабатываться и эксплуатироваться 
совершенно независимо друг от дру- 
га. Таким образом, подсистема, реа- 
лизованная нами на первом этапе 
работы, может быть оставлена в неизменном виде, а 
модули обработки — разрабатываться без оглядки на 
уже существующие структуры. Важным моментом 
практического использования системы является то, что 
накопление и обработка данных часто производятся 
совершенно различными службами заказчика, поэтому 
их совместное использование часто не только не обя- 
зательно, но и просто не нужно. 


БАЗА ДАННЫХ 


файлы 

ѴсІЫ: 


обмен данными 


| Файл |<- 
| исходных | 

I данных 


импорт 
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Обрабатывающий | - 

модуль 

0и і скВАЗІС 


Головной модуль системы 
РохВАЗЕ 

Подсистема накопления 
данных 


Головной модуль подсистемы 
обработки: 

1) анализ запросов; 

2) чтение исходных данных 
для обработки из БД и их 
импорт; 

3) запуск модуля обработки; 

4) экспорт результатов обра- 
ботки и запись их в БД 


і 


->| Файл 

результатов 


I 


Рис. 1. Основная схема организации системы при обеспечении обмена* 
информацией с базой данных средствами СУБД 
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Для реализации такой структуры системы необходи- ются в вызывающей программе пользователя. Зарезер- 

мо решить всего одну проблему — разработать под- вировав и правильно используя необходимое количест- 

программы обмена с файлами стандартных баз данных во блоков данных, пользователь может одновременно 

на соответствующем языке программировавния, в на- работать с несколькими базами данных и/или с нес- 
шем случае — на (ЗиіскВАЗІС. Мы так и сделали — колькими записями. Такая организация может в неко- 

создали библиотеку подпрограмм (}В-ОВР для работы торых случаях значительно сократить временные за- 

с файлами баз данных типа .ОВР и .ОВТ. Разработку траты, хотя и потребует незначительных раздумий при 

подпрограмм обмена данными с использованием ин- управлении данными. 

дексных файлов. мы отложили на будущее, так как в Использование подпрограмм обмена данными 2-го 
этом пока нет особой необходимости (учитывая специ- уровня обеспечивает удобный доступ пользователя к 
фику обрабатывающих программ, для которых время одной базе данных. Работа с новой базой данных (опе- 
выполнения операций поиска данных не является кри- рация открытия) может начинаться только после за- 
тичным). вершения работы с предыдущей (операция закрытия). 

Все рабочие массивы и пере- 
менные — описатели файла, 
содержимое записи и т.п. — 
резервируются в модуле 
0ВР_0ВРК.ВА5, непосред- 
ственный доступ к которому 
со стороны пользователя не- 
возможен. 

Рис. 2. Схеме организации системы при автономном обращении к базе данных Работа подпрограмм обмена 
различных модулей. данными 2-го уровня произво- 

дится через подпрограммы 1- 

Несмотря на то, что библиотека разработана в рам- Г о уровня. Соответственно могут быть реализованы два 
ках языка (}иіскВА5ІС, она может быть полезна и при варианта библиотеки: 

работе с другими языками: документация содержит — ОВРОВРКХІВ — полный состав библиотеки 
описание структуры файлов .ОВР и .ОВТ, а тексты (можно использовать подпрограммы 1-го и 2-го уров- 

подпрограмм — алгоритмы, которые достаточно легко ней); 

перевести на любой другой язык. — ОВР ОВРМ.ЫВ — библиотека без подпрограмм 

2-го уровня обмена данными (без модуля 

Общие сведения о библиотеке (ЗВПВР 0ВР 0ВРВ.ВА5). 


обмен 

данными 


БАЗА ДАННЫХ 


файлы 
*.СІ М\ * 


обмен 

данными 

<========= 


Подпрограммы библиотеки (}В_ПВР выполняют 
следующие основные функции: 

— поиск и открытие существующих файлов базы 
данных; 

— получение информации о структуре базы дан- 
ных; 

— чтение, коррекция, создание, удаление записей; 

— чтение, коррекция отдельного поля записи; 

— преобразование полей типа N и М в вид, удоб- 
ный для их последующей обработки. 

В состав библиотеки (2В_0ВР входят подпрограммы 
модулей ЭВР0ВРК.ВА5, ИВР0ВРМ.ВА5, 
0ВР_МЕМ0.ВА5, ПВР_$УМВ.ВА$, которые образуют 
4 основные группы: 

— обмена данными 1-го уровня (модули 

0ВР0ВРМ.ВА5, ОВРМЕМО.ВА5); 

— обмена данными 2-го уровня (модуль 

0ВР0ВРК.ВА5); 

— преобразования полей типа N и М (модули 
ОВР5ѴМВ.ВА5, 0ВР_МЕМ0.ВА5); 

— вспомогательные подпрограммы (модуль 
0ВР_5ѴМВ.ВА$). 

Пользователь имеет возможность непосредственно 
работать с подпрограммами первых 3 групп. 

При работе с подпрограммами обмена данными 1-го 
уровня все рабочие массивы и переменные резервиру- 


Состав подпрограмм 
библиотеки ()В_ОВР 


Подпрограммы обмена данными 1-го 


Модуль ОВГПВГМ.ВА5 

1. Открытие базы данных 

САІХ ОВР.Ореп (ІЬиГО, МГіе1с1$(), РПе$, Кгар, КЛеМ) 

2. Закрытие базы данных 
САІХ ОВР.СІозе (ІЬиГО) 

3. Выборка информации о поле с именем №тР$ 

ІЧПеІсІ = ѴЪГШеІд (МПе1сі$(), ШтР$, Іур$, ЬПеШ, Шее) 

4. Чтение описателя поля записи 

САІХ ЭВР.РіеІсі (МПе1с1$(), ІѴПеІсІ, N 801 ?$, !ур$, ЬПеМ, 
Шее) 

5. Чтение записи с номером N 2 ар или обнуление содержи- 
мого записи 

САІХ ПВР.СеіХ (ІЬиГО, 2$ут$, Ягар) 

6. Вывод на диск записи с номером N 2 ар 
САІХ ОВР.РШ2 (ІЬиГО, 2$ут$, Кгар) 

7. Выборка поля записи 

САІХ ОВР.СеІ.РіеІгі (МГіе1с1$0, Ріе1<1$, 2$ут$, Же\<\) 

8. Коррекция (запись) нового значения поля в запись 
САІХ ОВР.Рш.РіеІсі (МГіе1с1$(), РіеИ$, 2$ут$, Ше\д) 

9. Удаление записей файла 

САІХ ОВРХеІ (ІЬиГО, Ыхар, Кгар^ѵѵ) 

10. Отмена признака “помеченная к удалению“ для всех 
записей файла 

САІХ ОВР.КеОеІ (ІЬиГО, Коіг) 
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Модуль йВРМЕМО.ВАЗ 

1. Чтение текста поля из файла *.ОВТ 

САЬЬ ОВР.СеШепю(І5иГ(), Р1еМ$, Мето$, N51, КЫ) 

2. Вывод текста поля в файл *.ОВТ 

САЬЬ ЦВР.РиІ.Мешо (ІВиГО, Р1еІсі$, Мето$, N51, КЫ) 

Подпрограммы обмена данными 2-го уровня: 

Модуль ЭВРБВРК 

1 . Открытие базы данных 

САЬЬ ОВРК.Ореп (Рі1е$, Ктар, КПеІб) 

2. Закрытие базы данных 
САЬЬ ОВРК.СІове 

3. Определение имени и параметров поля по его 
порядковому номеру 

САЬЬ ОВРК.РіекИМіеіа, МатР$, Іур$, ЬПеІсІ, Ь<іес) 

4. Определение порядкового номера и параметров поля по 
его имени 

КПеІсІ = ОВРК.КПе1сі<КатР$, Іур$, ЬПеІсІ, Ьсіес) 

5. Чтение поля записи 

САЬЬ ОВРК.Се1.Ріе1<1(Ріе1сІ$, ІЧПеІсі, Хгар) 

6. Чтение записи в память или формирование новой запи- 

СИ САЬЬ 0ВГК.Сеі2(№ар) 

7. Вывод поля записи 

САЬЬ ОВРК.Ри!.Ріеіа<Ріе1с1$, ОТіеІсі, N 2 ар) 

8. Сброс признака коррекции текущей информационной 
записи 

САЬЬ ЭВРК.С1еаг2 

9. Вывод текущей записи в базу с номером Кгар 
САЬЬ 0ВРК.РіЛ2(Кгар) 

10. Удаление записи из файла 
САЬЬ ОВРК.ОеШКгар, Ктар^ш) 

11. Удаление “помеченных** записей 
САЬЬ ОВРК.ОеІ.АИ (КхарКеѵ) 

12. Очистка файла — удаление всех записей 
САЬЬ ОВРК . Цеі . Сіеаг (КгарКеш) 

13. Отмена признака “помеченная к удалению" для всех 
записей файла 

САЬЬ ОВРК.КеОеІ (Коіг) 

Подпрограммы преобразования полей типа N и М 
Модуль ОВРМЕМО ( поле М) 

1. Представление текста формата МЕМО$ в виде массива 
МешоМ$() 

САЬЬ ОВР.Мето.СеіМ (Мето$, МетоМ$(), косі) 

2. Представление текстового массива МетоМ$() в формат 
текста МЕМО$ 

САЬЬ ОВР.Мето.РиіМ (Мето$, МетоМ$(), КтетоМ) 
Модуль йВР ЗУМВ (поле АО 

1. Преобразование поля типа N в число, Рогш$ — формат 
числа 

Ріе1с1$ = ОВР.ЗіЖ$ (АлишЬ, ЬПеІсІ, Ыес) 

2. Преобразование вещественной переменной АпшпЬ в 
символьное поле типа N 

АпшпЬ = ОВР.ЫшпЬ (Ріе1с1$, Ыес, Рогга$) 

Общепринятые обозначения 
формальных параметров 

Параметры Файла: 

Рі1е$ — имя базы данных (имя файла *.ОВР 


без расширения); 

Кгар — количество записей в файле, получен- 
ное при открытии файла; 

КгарЫеѵ — текущее значение количества записей 
в файле (полученное в результате коррекции длины 
файла); 

КЛеІб — количество полей в записи; 

ЫЛеІсІ — порядковый номер поля записи 
( «О — работа с байтом состояния записи). 

Параметры поля записи: 

ЫашР$ — имя поля; 

1ур$ — код типа записи (С, N. О, Ь или М); 

Іііеісі — длина поля в символах; 

Ьсіес — количество цифр после запятой поля ти- 
па N. 

Параметры записи: 

Ыхар — номер записи; 

Ріе1<1$ — значение поля записи, идентифи- 

цируется порядковым номером ЫЛеІб, при этом зна- 
чение ЫЛеІсІ = 0 соответствует работе с байтом состоя- 
ния записи: 

Ріе1с1$ - “*“ — “помеченная к удалению 44 , 

= “ “ — “непомеченная 44 . 

Модуль ИВР_рВРМ. ВА8: 

ІЬиШ Іо 11) — блок управления базой; 

МПе1сі$(1 Іо КПеІб) — массив описателей полей 
определяется динамическим массивом в вызывающей 
программе, при отрытии базы его размерность переоп- 
ределяется в подпрограмме ОВР.Ореп; 

2зуш$ — содержимое записи. 

Модуль ОВР^МЕМО. ВАЗ: 

Мето$ — текст поля МЕМО (содержимое записи 
файла *.сіЫ); 

N51 — номер начального блока: N51 * 

ѴАЬ(Ріе1сІ$); 

КЫ — количество блоков под данным текстом 
Мето$. 

ПРАКТИЧЕСКАЯ РАБОТА 
С БИБЛИОТЕКОЙ ОБ йВР 


Схема основных действий при работе с биб- 
лиотекой (ЗВ_БВР 

1. Открытие базы данных — файлов .ОВР и .ОВТ 
(файл .ОВТ открывается только, если есть поле 
МЕМО). 

2. Обмен данными (чтение/запись). Реализованы 
основные операции: 

— определение параметров поля записи (дальней- 
шая обработка полей записи производится по порядко- 
вому номеру поля); 
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— чтение, коррекция (вывод в файл) отдельного 
поля записи, преобразование полей типа N и М в вид, 
удобный для их последующей обработки; 

— работа с целой записью (чтение и вывод записи, 
создание новой записи, удаление отдельной записи 
или всех “помеченных 44 записей, отмена признака 
“помеченная 44 у всех записей файла и пр.). 

3. Закрытие текущей базы данных: 

— описатели базы освобождаются для работы с дру- 
гой базой данных. 

Организация работы с подпрограммами 
обмена 1-го уровня 

При работе с подпрограммами обмена 1-го уровня 
резервирование и хранение описателей базы данных 
производится в вызывающей программе пользователя. 
Пользователь использует соответствующие массивы и 
переменные в течение всего сеанса работы с базой 
данных — от операции открытия до ее закрытия. 

При работе с несколькими базами данных одновре- 
менно пользователь должен зарезервировать у себя в 
программе соответствующее количество служебных 
массивов для каждой базы. 

Организация работы с подпрограммами 
обмена 2-го уровня 

При открытии базы данных в модуле 
ЭВР_ОВРК.ВА$ формируются блоки управления фай- 
лами и описателей полей. Обмен данными ФАЙЛ- 
ПАМЯТЬ выполняется на уровне отдельной записи. 
Сама запись хранится в модуле 0ВР_0ВРК.ВА5, в ко- 
тором также фиксируется номер текущей (в памяти) 
записи ЫгарВ и код ее состояния ІсоггХ ( = 0 — за- 
пись не корректировалась, т.е. ее содержимое в памя- 
ти и в файле идентично, 1 — запись корректирова- 
лась, требуется ее вывод на диск). Обмен данными 
ПОЛЬЗОВАТЕЛЬ-ФАЙЛ выполняется на уровне от- 
дельных полей записи. 

Управление обменом ФАЙЛ-ПАМЯТЬ выполняется 
автоматически по такому алгоритму: 

— если записи с заданным номером в памяти нет, 
то она читается с диска, но перед этим производится 
проверка состояния текущей записи; 

— если запись корректировалась, то производится 
ее автоматический вывод на диск. 

Таким образом, коррекция данных может осущест- 
вляться без выполнения операции вывода записи в 
файл пользователем в явном виде — вывод откоррек- 
тированной или вновь созданной записи выполняется 
автоматически при чтении новой записи или закрытии 
базы. 

Примеры применения 
подпрограмм библиотеки 

Примеры реализации отдельных операций с файла- 
ми баз данных типа .ОВР и .ОВТ с использованием 

4 


подпрограмм библиотеки (2В0ВР приведены в тексте 
модуля 0ВР_ЕХМ.ВА5 и оформлены в виде отдельных 
процедур. 

Представленные процедуры соответствуют варианту 
использования подпрограмм обмена данными 1-го 
уровня. Конструкции с использованием подпрограмм 
2-го уровня показаны в тексте в виде комментария. 

Программы модулей ЭВРМ_01.ВА5 и 
ЭВРК_01.ВА$ демонстрируют вариант полного сеанса 
работы с базой данных через подпрограммы библиоте- 
ки. 

Исходные тексты модулей 0ВР_ЕХМ.ВА5, 
ОВРМ_Э1.ВА5 и 0ВРК.Ш.ВА5 приводятся в конце 
статьи. 

Варианты будущего развития 
библиотеки (}В_рВР 

Имеются два основных варианта развития функцио- 
нальных возможностей библиотеки подпрограмм 

двэвр. 

1. Разработка подпрограмм, выполняющих более 
сложные логические операции (например, поиск запи- 
си по ключу) через имеющийся набор подпрограмм 1- 
го или 2-го уровня. Очевидно, что эта задача по силам 
практически любому программисту средней квалифи- 
кации. 

2. Разработка подпрограмм, выполняющих более 
сложные логические операции, в рамках 1-го уровня 
подпрограмм, т.е. реализация специальных алгоритмов 
обмена ПАМЯТЬ-ДИСК, учитывающих особенности 
данной операции. Это может значительно оптимизи- 
ровать время ее выполнения. Примером такого дей- 
ствия может являться операция поиска записи по клю- 
чу. Существующий набор подпрограмм ориентирован 
на чтение записи целиком. Создав подпрограмму чте- 
ния и сравнения только одного поля, вы значительно 
сократите время поиска для файлов с большой длиной 
записи. Примером такой подпрограммы является 
ЭВР.КЕЭЕЬ (модуль 0ВР_0ВРМ.ВА5). Разумеется, 
для этого необходимо иметь некоторый опыт работы с 
файлами типа “ВѴЫАКУ 44 и знать структуру файлов 
.ОВР и .ОВТ. 

Поставка программного продукта осуществляется в 
следующих вариантах: 

— библиотека подпрограмм дв_ОВР.ІЛВ (объект- 
ные модули), описание состава и спецификаций под- 
программ; 

— исходные тексты подпрограмм, описание струк- 
туры файлов .ОВР и .ОВТ. 

В состав этих двух вариантов поставки входят об- 
щее описание библиотеки, примеры реализации основ- 
ных программных конструкций с использованием под- 
программ 1-го и 2-го уровней. 

Второй вариант поставки будет полезен при созда- 
нии аналогичных подпрограмм для других языков, 
обеспечит возможность эффективного расширения 
функциональных возможностей данной библиотеки. 
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ОПЫТ РАЗРАБОТКИ СПЕЦИАЛИЗИРОВАННЫХ БАЗ ДАННЫХ 


Модуль ОВР-ЕХМ. ВАЗ 


ОЕСЬАНЕ ЗОВ 

ОЕСІ-АНЕ ЗОВ 
ОЕСІ-АНЕ ЗІІВ 

ОЕСІ-АНЕ 51)В 

ОЕСІ-АНЕ 31)В 

ОЕСІ-АНЕ ЗУВ 


ОВР.Ореп ( I ЬцР%( ) , МИе10$(), РИе$, 
Кгар% , КР іе 10%) 
ОВР.ОеІ ( I ЬиТ%( ) . Мгар%, Кг%) 

ОВР. ОеП Мето (ІЬиТ%(). Ріе10$, 

Мето$, N61%, КЫ%) 

ОВР . Мето . СеТМ (Мето$, МетоМ$(), 
ко0%) 

ОВР. РиН. Мето (ІЬиР%(), Ріе10$, 

Мето$ , N61%, КЫ%) 
ОВР . Мето . РиНМ (Мето$, МетоМ$(), 


КтетоМ%) 


ОЕСІ-АНЕ ЗЫВ 0ВР.РиН2 (І6иР%(), 2зут$ , Мгар%) 
ОЕСІ-АНЕ ЗЫВ ОВР . РиП . Ріе 10 (МТіе10$( ) . 2зут$ , 

Ріе 10$ , ММе 10%) 

ОЕСІ-АНЕ ЗЫВ ОВРИ . РиН . Ріе 10 (Ріе 10$ , МПе10%, 

Мгар%) 


ОЕСІ-АНЕ ЗОВ 

ОЕСІ-АНЕ ЗЫВ 
ОЕСІ-АНЕ ВИВ 

ОЕСІ-АНЕ зив 

ОЕСІ-АНЕ ЗУВ 


ОВР . СеН . Ріе 10 (МРіе 10$( ) , 2зут$ , 
Ріе 10$ , МРіе 10%) 

0ВР.СеН2 ( І6иР%( ) , 2зут$ , Ы 2 ар%) 
ОВР . Ріе 10 (МРіе10$( ) , ЫРіе 10%, 

МатР$ , Нур$ , Ніе10%, Ь0ес%) 
ОВРР . Ріе 10 (ЫРіе 10% , МатР$ , Нур$ , 
Н іе 10% , 1_0ес%) 

ОВРР. Сен. Ріе10 ( Ріе 10$ . іте10%, 


Мгар%) 


ОЕСІ-АНЕ ЗОВ ОВРР.Ореп (Рі1е$, Кгар%, КРіе10%) 
ОЕРІЫТ І-Ы 

ОЕСІ-АНЕ РимСТІОМ ОВР . МР іе 10 (МРіе 10$( ) . МатР$ , 

Иур$, ЬР і е 10 , 1_0ес) 

ОЕСІ-АНЕ РиЖГЛОМ ОВРР . ЫР іе 10 (МатР$, *ур$ , 

ЬРіе 10 , Ь0ес) 

ОЕСІ-АНЕ РиМСТІОМ ОВР . Зн гЫ$ (Апитб, И=іе10, 1_0ес) 
ОЕСІ-АНЕ РШІСТІОЫ ОВР. Митр ( Ріе 10$ . 1_0ес , Рогт$) 

•А********************************************** 


Примеры работы с файлами типа *.ОВР и * . ОВТ 
с использованием подпрограмм библиотеки 
ОВ-ОВР. ИВ: 

1) обмена данными 1-го уровня (ОВР-ОВРМ); 

2) обмена данными 2-го уровня (ОВР-ОВРР) . 


Примеры представлены в виде текстов 
подпрограмм 

Подпрограммы относятся к варианту ОВР-ОВРМ, 
соответствующие конструкции варианта ОВР-ОВРП 
приведены в виде фрагментов комментариев 




ОТКРЫТИЕ СУЩЕСТВУЮЩЕЙ БАЗЫ ДАННЫХ *** 

РіІе$ ■ "Вазе” ’ имя базы данных без 

расширения 
открываются файлы 
Вазе.0ЬР и 
Вазе.0ЬН (если есть 
поле МЕМО) 

ОВРМ г 

ОІМ І6иР(1 ТО 15) 'резервируем массив под блок 
’ управления базой 
'фиктивное резервирование массива 


'описателей полей: 

ПЕОІМ МИе10$(1) 

'открываем базу данных, имя файла - РПе$ 
САН ОВР . Ореп( ІЬи^( ) , МТіе10$(). Рі1е$, 
К 2 ар, КМе 10) 

Если все ОК (Кгар >= 0) - в подпрограмме 

ОВР . орер 

производится переопределение массива: 

ПЕОІМ МРіе 10$( 1 ТО КРіе 10) 
и формирование массивов ІЬиР() и МРіе10$() 

До момента завершения работы с базой данных 
(закрытия) пользователь должен обеспечить 
сохранность 

массивов ІЬиР() и МРіІе0$(). 

Эти массивы используются в дальнейшем при 
работе с подпрограммами обмена данными для 
идентификаций нужной базы данных 

ОВРР 

’ САИ ОВРП . Ореп(Рі 1е$ , Кгар, КРіе10) 


ЕЫО 


' Кгар - кол-во записей в файле 
’ КРіе10 - кол-во полей в записи 
’ анализ кода завершения операции открытия:. 

ІР Кгар = -1 ТНЕЫ ЗТОР ' файла нет 

ІР Кгар = -2 ТНЕЫ ЗТОР * Кгар > 32767 ! 

ІР Кгар = -3 ТНЕЫ ЗТОР ’ не найден файл 

*.0бТ(а был нужен!!) 


ОЕРЗМО ІНЧ 
РЕРІМТ І-Ы 

ЗОВ йВРМЕ.Сору (ІЬиТ(), Мгар.деП Ыгар.риТ, 

Кгар) 

'ЗиВ ОВРПЕ . Сору (Ыгар-деТ, Ыгар.риТ, Кгар) 
.********** КОПИРОВАНИЕ ЗАПИСИ ФАЙЛА ******* 
'ВХОД: 

Ыгар.деТ - номер записи, ОТКУДА копируем 
= 0 - очистка исходной записи 
Ыгар.риТ - номер записи, КУДА копируем 
= -1 - добавить новую запись 

’ ВЫХОД : 

Кгар - новое кол-во записей в файле, 

’ если Мгар.риТ=-1 

(требуетоА анализ: Кгар < 0 - 
код ошибки) 

************************************************ 
Кгар = Мгар.риТ ’ при создании новой 
' записи Кгар 
' будет изменен 

• ОВРМ 

' обнуление 

САН ОВР . СеТ2( І6иР( ) , 2зут$ , Мгар.деТ) 

' вывод новой записи 

САН ОВР . Ри*2( І6иР( ) , 2зут$ , Кгар) 

• г — овРП 
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’ САН ОВРР . 6еі2(Мгар . деі ) 
’САИ 0ВРР.Ри12(Кгар) 


ЕМ 811В 

8М ОВРМЕ.СОРР ( I ЬиР ( ) , МПе 16$( ) , Кгар) 

'ВМ ОВРРЕ.СОРР ( Кгар ) 

’ ** ПОИСК ЗАПИСЕЙ с ЗАДАННЫМ ЗНАЧЕНИЕМ ПОЛЯ **** 

* * * и КОРРЕКЦИЯ ДАННОГО ПОЛЯ НА НОВОЕ ЗНАЧЕНИЕ * 

Кгар - кол-во записей в файле 
************************************************ 

ІИРІІТ "Имя поля - "; МатР$ 

получение информации о поле ИатР$ 

• оврм 

ЫНеІб = ОВР . М1іе16(М1іеІб$() , ЫатР$ , іур$ , 
Ніеіб, Шее) 

ОВРР 

' N ^ і I есі = ОВРР . N1 іе 16( МатР$ , 1ур$, Иіеіб, Шее) 


'МРіеН - пор. номер поля записи: 

'дальше работаем с ним! ! ! ! 

ІР ІМРіеІб = О ТНЕИ РРІІМТ ” Поля с таким 
именем нет ! ! ” : ЕХІТ 811В 

ввод значения поля (считаем, что тип поля - 
N или С) 

ІР 1ур$ = "ІГ ТНЕИ 

ІМІІТ "Искомое значение числового поля”; 
Оеса I 

ІМІІТ "Новое значение числового поля"; 
Оеса ІИ 

преобразование десятичного значения в 
' поле типа N 

Ріе 16ІЧеѵ/$ = ОВР . 8ігМ$(0ес ІаИ , НЧеІб, 
Шее) 

Е1_8Е 

ІМІІТ "Искомое значение символьного 
поля" ; 8утЬ$ 

ІМІІТ "Новое значение символьного поля" ; 
Ріе 16ІМеѵѵ$ 

ЕМ ІР 

поиск записи с заданным значением поля и ее 
’ коррекция 

КоІ 2 = 0 ' кол-во найденных и 

откорректированных записей 
РОР Ыгар = 1 ТО Кгар 

• - 0ВРМ 

САН ОВР . Се12( ІЬи1( ) , 2зут$ , Ыгар) ’ чтение 

* записи - 2зут$ 

САН ОВР . Сеі .Ріе16(М1іе16$()-, 2зут$ , 

Ріе 16$ , ітеіб) 

• ОВРР 

' САП ОВРР . Сеі .Ріе16(Ріе16$, ИРіеШ, ІЧгар) 


ІР 1ур$ = "И" ТНЕИ 

преобразование символьного поля в число 
Оесаіг = ОВР І\ІитЬ(Ріе16$, Шее, Рогт$) 
ІР Оеса I 2 = Оеса I ТНЕЫ С081ІВ ОиІ.РіІе 

Е18Е 

ІР 8утЬ$ = Ріе 16$ ТНЕИ С081ІВ ОиІ.РіІе 
ЕМ ІР 
МХТ ІМгар 

окончание просмотра файла 
РРІІМТ "Кол-во откорректированных записей = ", 
Ко І2 

ЕХІТ 80Ѳ 

вывод нового значения поля 
Оиі . Рі Іе : 

Ко 1 2 = Ко I г + 1 ’ счетчик откорректиро- 

’ ванных записей 

• ОВРМ 

САП 0ВР.РиИРіе16(МГіе16$() , 2зут$ , Ріе16$, 

N1 іе 16) 

САП ОВР . Ри12( ІЬиІ ( ) , 2зут$ , ІМгар) ’ вывод 

записи в файл 

• ОВРР 

1-й вариант - номер записи задан в явном виде: 
*САП ОВРР . Риі .Ріе16(Ріе16$, Мііеіб. Ыгар) 
2-й вариант - работа с текущей записью: 

САП ОВРР . Риі . Ріе ІббРіе 16$ , ГМІіеІб. 0) 


РЕТМИ 
ЕМ 80В 

811В ОВРМЕ . Сгеаі . Му* (Іви1(), Кгар) 

’81ІВ ОВРРЕ . Сгеаі . ІМеѵ»/ (Кгар) 

****** Добавить новую запись в конец файла ***** 
1 ВЫХОД : 

Кгар - новое кол-во записей в файле 

(требуется анализ ошибки - Кгар < 0) 

•А********************************************** 

Кгар = -1 ' код создания новой записи 

• ОВРМ 

САП ОВР . Се12( ІЬиР ( ) , 2зут$ , 0) ’ обнуление 

САП ОВР . Риі2( ІЬиІ ( ) , 2зут$ , Кгар) ’ вывод новой 

’ записи 

ОВРР 

•САП' ОВРР . Се12( О ) 

*САП ОВРР . Риі2( Кгар ) 

ЕМ 81)В 

81Ш 0ВРМЕ.0Е1. (ІЬи1(), Мгар, Кгар) 

•80В ОВРРЕ. 0Е1_ (Ыгар , Кгар) 
*********************** ************************* 

.******************* УДАЛЕНИЕ ЗАПИСИ из файла 
Игар - номер удаляемой записи 

’ ВЫХОД : 

Кгар - новое кол-во записей в файле 
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(требуется анализ: Кгар < 0 - 
’ код ошибки) 

• ОВРМ 

САН ОВР . Эе I ( I Ьи 'Г ( ) , Мгар , Кгар) 

• оврв 

*САН ОВРВ . йе 12(Мгар , Кгар) 


ЕЫй ВЫВ 

ВОВ ОВРМЕ.Мето.Меѵ* (ІЬиРО. МНеИ$(), Мгар, 
МатР$ ) 

•ВЫВ ОВРВЕ.Мето.Меѵ* (Мгар, МатР$) 

•А********************************************** 

’ **** ВВОД НОВОГО ЗНАЧЕНИЯ пбля типа МЕМО ****** 
Игар - номер корректируемого поля 
’ ИатР$ - имя поля с типом МЕМО 
'ВНИМАНИЕ! Даже при записи НОВОГО значения поля 
‘МЕМО следует предварительно считать в память 
’его старое значение, так как только эта опера- 
’ ция позволит оптимизировать процедуру физичес- 
’кого размещения данных в файле сШ* . 

• оврм 

’ получение информации о поле ИатРІ: 
ИГіеИ = 0ВР.МНеІб(МНеІс1$() , МатР$, Тур$, 
І_НеИ, Ібес) 

' чтение поля МЕМО 

САП ОВР . СеТ2( ІбиГ( ) , 2зут$ , Мгар) ’ чтение 

’ записи 

САП ОВР .Се* . РіеІс1(МНеІсІ$( ) , 2зут$ , РіеІс1$, 
ИРіеН) ’ чтение адреса поля 
САП ОВР . Се* . Мето( ІбиГ ( ) , РіеИ$, Мето$ . N61. 

КЫ ) ’ чтение поля 

’ Значения N61 и Кб I необходимо сохранить* ! 

’ Если чтение поля МЕМО не производилось, 

’ надо установить N61=0, Кб 1=0 

• ОВРВ 

’ МН Іей =' ОВРВ . МНеІсІ(МатР$ , Тур$, І_НеН, ПІес) 

’САП ОВРВ. бег. Ріе ІСІ( Ріе ІсІ$ . N1= іе Ісі , Мгар) 

ОІМ МетоМ$(10) ‘ резервируем массив под 
’ текст поля 

РВІМТ "Вводите текст поля МЕМО, пустая 
строка - конец ввода" 

Кт = 0' счетчик строк 
00 

ІЛЫЁ ІМРУТ а$ : ІР а$ = "" ТНЕМ ЕХІТ 00 
Кт = Кт + 1 : МетоМ$(Кт) = а$ 

Ю0Р 

’ преобразование символьного массива в 
' формат строки МЕМО в файле 
САП ОВР. Мето. РиТМ(Мето$, МетоМ$(). Кт) 


запись в файл 


оврм 

САП ОВР . РиГ . Мето( ІбиГ ( ) , РіеИ$, 
N61, Кбі) 


Мето$ , 


САП 0ВР.Ри*.Р1е1й(МНе1й$(). 2зут$ , 
РіеЫ$, МПеІсІ) 

САП ОВР . Ріі*2( 1 биР ( ) , 2зут$, Мгар) 

' вывод записи в файл 

• ОВРВ 

’ САП ОВРВ . РиГ.РіеІсі(РіеІс1$, МПеІсІ, Мгар) 

ЕМ0 зив 

зив 0ВРМЕ . МЕМО . ОиГ (ІбиРО, МПеШ$()) 

’зив ОВРВЕ.МЕМО.ОиТ 

************************************************ 

' * ВЫВОД на экран содержимого всех полей МЕМО ** 
********** одной записи файла ****************** 
ІМРУТ "Номер записи - "; Мгар 
' КНеШ - кол-во полей записи - определяется 
’ при отрытии файла 

• оврм 

САП ОВР . СеГ2( ІбиГ ( ) , 2зут$ , Мгар) ’ чтение 

’ записи - 2зут$ 

• ОВРВ 

’ чтение записи в явном виде не надо производить 

РОВ МПеІсІ = 1 ТО КПеИ 

определение типа поля 

• оврм 

САП ОВР РіеН(МИеН$(), МПеН. МатР$. *ур$ , 
ЕНеИ. 1_с1ес) 

• ОВРВ 

САП ОВРВ.РіеІсКМНеіи, МатР$ , Гур$, Иіеісі. 

’ Ёсіес) 

ІР Гур$ = "М" ТНЕМ 

РВІМТ "Поле типа МЕМО, имя поля - "; 
МатР$ 

оврм 

САП ОВР.0е*.РіеІ(1(ММеІСІ$() , 2зут$, Ріе1б$. 
МПеІсІ) 

САП ОВР . Се* . Мето( ІбиГ ( ) . Ріе1б$, 
Мето$ , N61, Кбі) 

• ОВРВ 

‘САП ОВРВ . СеТ . Ріе 1б(Мето$ , МПЕІСІ, Мгар) 

’ Мето$ - значение поля МЕМО 
ІР Мето$ = "" ТНЕМ 

РВІМТ и Пустое значение" 

' резервируем массив для выделения 
’ полей текста МЕМ0$ 

ВЕ0ІМ МетоМ$( 1 ТО 1) 

САП ОВР . Мето . СеТМ ( Мето$ , 

МетоМ$(), 0) 

РОВ і = 1 ТО иВ0УМ0(МетоМ$) 

РВІМТ МетоМ$( і ) 

МЕХТ 
ЕМ0 ІР 
ЕМ0 ІР 
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ЫЕХТ ЫТіеЮ 
ЕМ 811В 

бИВ ОВРМЕ . МеТ <ІЬиТ(), МТіеІй$(), Ыгар, кой) 

•ЗЫВ ОВРЯЕ.МеТ <ІЬиТ(), МТіеІй$(), Игар , кой) 
************************************************ 

’ кой в 0 - пометить запись как "удаленную" 

> 0 - отменить . . . 

Игар - номер удаляемой записи 

ІР кой = О ТНЕЫ РіеІй$ = "*" ЕЬВЕ РіеЮ$ * 

• 0ВРМ 

САН ОВР . 0еТ2( І6иТ( ) , 2зут$ , Игар) ’ чтение 

’ записи - 2зут$ 
САН ОВР . РиТ . Ріе 1й(МНе Ій$( ) , 2зут$, Ріе1й$, 
0) ‘ Ы^іе 1й*0 ! 

САП ОВР . РиТ2( ІЪи^( ) , 2зут$ , Игар) ' вывод 

’ записи в файл 

• 0ВРР 

’ САП ОВРН .РиТ .РіеІй(РіеІй$, 0, Ыгар) 

' хг==ггг:::г:гз=е:г:гх=зггзг2=ггз2гс:гг:хггхггг= 

ЕМ СМ 

811В ОВРМЕ . 8ТРІІС . СЕТ (МПеІй$(), КТіеІй) 

'ВИВ ОВРРЕ . 8ТВІІС . СЕТ (КПеІй) 
************************************************ 

***** ЧТЕНИЕ СТРУКТУРЫ ЗАПИСИ БАЗЫ ДАННЫХ ****** 
' КТіеІй - кол-во полей записи 


ОЕРІИТ І-Ы 

ОЕСЬАВЕ риыстюм ІпТЗут (а$, Изут) 

ОЕСЬАРЕ РОЫСТІОМ ОВР.ЫГЧеЮ (МПеІй$<), ЫатР$, 

Тур$ , Ніеій, 1_йес) 

0ЕС1АРЕ РОИСТЮМ ОВР.ЫитЬ (РіеІй$, Ьйес, Рогт$) 

обращение к подпрограммам библиотеки 
0ВР-0ВРМ.НВ 


ІИРІІТ "Введите имя базы (без расширения) - 
РПе$ 


ОІМ ІЬиТ(1 ТО 15) 

’ фиктивное резервирование массива описателей 
’ полей : 

РЕОІМ МНе1й$(1) 

’ открытие файла ♦ чтение реквизитов файла + 

’ + перерезервирование массива описателей 

’ полей и его чтение из файла 

САП ОВР . 0реп( ІЬиТ( ) , МНеЮ$<), РПе$, 
Кгар, КГіеІй) 

ІР Кг * 1 ТНЕИ ВТОР ’ файла нет 

ІР Кг *= 2 ТНЕЫ 8Т0Р ' это не * йЪГ 


РРІКІТ "Кол-во записей = Кгар 

РРІЫТ "Полей в записи * "; К^іеій 

вывод на экран 

САП ОВРМЕ. 8ТМС. 0ЕТ(МНе1й$() , КНеІй) 


РРІЫТ " Описание полей:" 

РРІИТ "Имя ", "Тип", "Длина", "Дробь" 

РОР ИТіеЮ * 1 ТО КПеІй 

• 0ВРМ 

САП ОВР . РіеІй(М^іеІй$( ) , ЫТіеІй, ЫатР$, 
Тур$, Ніеій, Ьйес) 

• ОВРЯ 

’ САП ОВРН.РіеІйСЫПеІй, МатР$, Тур$, 1_ТіеІй, 
1-йес) 

РРІЫТ ЫатР$, Тур$, Иіеій, І_йес 
ЫЕХТ ЫПеІй 
ЕИО 8УВ 


Модуль 0ВРМЮ1 . ВАЗ 

ОЕСЬАРЕ ВЬВ ОВР. С Юзе (ІЬиГ%()) 

ОЕСЬАРЕ ВИВ ОВРМЕ . 8ТРЫС . СЕТ (МТіеЮ$(), КНеЮ%) 
ОЕСЬАРЕ 80В ОВР.СеТ.РіеЮ (МПеІй$(), 2зут$ , 

Ріе Ій$ , МНеІй%) 

ОЕСЬАРЕ 80В ОВР.Ореп <ІЬиТ%<), МТіеІй$(), РПе$, 
Кгар% , К^іе 1й%) 

ОЁСЬАРЕ ВОВ ОВР. Мето. ОеТМ (Мето$, МетоМ$(), 

кой%) 

ОЕСЬАРЕ ВОВ ОВР . СеТ . Мето (ІЬи^О, Ріе1й$, 

Мето$ , N61%, КЫ%) 
ОЕСЬАРЕ ВОВ 0ВР.СеТ2 ( ІЬи^%( ) , 2зут$ , Ыгар%) 


чтение записи с номером Ыгар в символьную 
константу 2зут$ 

00 

ІИРИТ "Номер записи - "; Ыгар 
ІР Ыгар = О ТНЕИ ' конец работы 
САП ОВР . С 1озе( ІЬиІЧ ) ) : ЕЫО 
ЕИО ІР 

ІР Ыгар <= Кгар ТНЕИ ЕХІТ 00 * проверка 

' значимости номера 
РВІИТ " Ошибка в номере записи " ; 

ЮОР 

чтение записи 

САП ОВР . 0еТ2( ІЬи^ ( ) , 2зут$ , Игар) 


выборка поля 

00 

ІИРШТ "Имя поля - "; ИатР$ 

получение информации о поле ИатР$ 

И^іе Ю - ОВР . М^іеІй(М^іеІй$( ) , МатР$, Тур$, 
Ніеій. 1_йес) 

ЫТіеЮ - пор. номер поля записи: дальше ра 
ботаем с ним ! ! ! ! 

ІР ИГіеЮ <> О ТНЕЫ ЕХІТ 00 
РНІЫТ "Такого поля нет!"; 

ЮОР 

САП ОВР.СеТ . РіеІй(МТіеІй$( ) , 2зут$, 

РіеІй$ , ЫПеІй) 

КомпьютерПресс 5'91 





62 


ОПЫТ РАЗРАБОТКИ СПЕЦИАЛИЗИРОВАННЫХ БАЗ ДАННЫХ 


РРІИТ "Поле г- РіеІ<3$ 

ІР Тур$ = "И" ТНЕЫ 
’ преобразование числового поля 
Оесаі * ОВР . МитЬ(Ріе 16$ , 1_6ес, Рогт$) 
РРІИТ "Оеса I , Рогт$ = "; : РРІИТ УЗІЫС 

Рогт$; Оесаі 

ЕИО ІР 

ІР *ур$ = "И” ТНЕИ 
’ чтение + обработка текста МЕМО 

САН ОВР . Се* . Мето( ІЬи^( ) , Ріе16$, Мето$ , 
N61, КЫ) 

ІР Мето$ <> ,,и ТНЕМ 

* резервируем массив для выделения 
’ полей текста МЕМО$ 

РЕОІМ МетоМ$( 1 ТО 1) 

• САН ОВР . Мето . 0еі:М(МетО$ , МетоМ$(), 0) 
РОР і = 1 ТО 0В01ІМ0( МетоМ$ ) 

РРІМТ МетоМ$(і) 

МЕХТ 
ЕЫО ІР 
ЕИО ІР 

ЕМО 


Модуль 0ВРРЮ1 . ВАЗ 


ОЕСЬАРЕ ЗІІВ ОВРР.сІове () 

ОЕСЬАРЕ ЗЫВ ОВРР.РіеІб (МТіеІсІ%. НагаР$ , Тур$ , 

Ніе16%, 1_6ес%) 

ОЕСЬАРЕ ЗОВ ОВРР . Се* . Ріе 16 (Ріе16$, ММе16%, 

N230%) 

ОЕСЬАРЕ ЗІІВ ОВРР.Ореп (РПе$, Кгар%, КТ іе ІсІ%) 
ОЕСЬАРЕ ЗІІВ ОВР . Мето . СеТМ (Мето$, МетоМ$(), 

ко6%) 

ОЕРІМТ І-И 

ОЕСЬАРЕ РІШСТІОМ ОВРР . N1= іе 16 (МатР$, Тур$ , 
Иіеіб, І_6ес) 

ОЕСЬАРЕ РУМСТІОМ ОВР. Митр (Ріе16$, І_6ес, Рогт$) 


обращение к подпрограммам библиотеки 
ОВР-ОВРРПІВ 


сі_з 

ІИРІІТ "Введите имя базы 
"; Рі1е$ 

(без расширения) - 

* открытие базы данных 


САП ОВРР . Ореп(Рі 1е$ . 

Кгар, КНе 16) 

ІР Кг = 1 ТНЕИ ЗТОР 

* файла нет 

ІР К2 = 2 ТНЕИ ЗТОР 

’ это не * . 6Ы 1 


РРІМТ "Кол-во записей = Кгар 
РРІМТ "Полей в записи = "; КНеІб 


вывод на экран 
РРІМТ'” Описание полей:" 

РРІМТ "Имя ", "Тип", "Длина", "Дробь" 


РОР МТіеІб = 1 ТО КТіеІб 

САП ОВРР. Ріе16(МНе16, МатР$, Тур$ , 
І_Тіе 16 , Ьбес) 

РРІМТ МатР$ , Тур$, Иіеіб, 1_6ес 
МЕХТ ИПеІб 


чтение записи с номером Игар в символьную 
' константу 2зут$ 

00 

ІИРОТ "Номер записи - "; Игар 
ІР Игар = О ТНЕИ ’ конец работы 
САП ОВРР.сІозе: ЕИО 
ЕИО ІР 

ІР Игар <= К 2 ар ТНЕИ ЕХІТ 00 1 проверка 

' значимости номера 
РРІИТ " Ошибка в номере записи "; 

ЮОР 

выборка поля 

00 

ІИРІІТ "Имя поля - " ; ИатР$ 

получение информации о поле ИатР$ 

ИТіеІб = ОВРР . ИНе 16(МатР$ , Тур$ , Ніеіб, 

І_6ес) 

ИТіеТб - пор. номер поля записи: дальше ра 
’ ботаем с ним ! ! ! ! 

ІР ЫМеІб <> О ТНЕИ ЕХІТ 00 
РРІИТ "Такого поля нет!"; 

ЮОР 

САН ОВРР. Сет. Ріе16(Ріе16$, ИНеМ, Игар) 

ІР Тур$ <> ”М" ТНЕИ 

РРІИТ "Поле - "; Ріе 16$ 

ІР Тур$ = "И" ТНЕИ 

преобразование числового поля 
Оесаі = ОВР . МитЬ(Ріе16$ , Юес, Рогт$) 
РРІИТ "Оесаі, Рогт$ = "; : РРІИТ ІІЗІИС 
Рогт$; Оесаі 
ЕИО ІР 
Е1_ЗЕ 

чтение + обработка текста МЕМО 
Мето$ = Ріе16$ 

ІР Мето$ <> "" ТНЕИ 

резервируем массив для выделения 
' полей текста МЕМ0$ 

РЕОІМ МетоМ$( 1 ТО 1) 

САП ОВР. Мето. ОеТМ(Мето$, МетоМ$(), 0) 
РОР і = 1 ТО 0В0иМ0(МетоМ$) 

РРІИТ МетоМ$(і) 

ИЕХТ 
ЕИО ІР 
ЕИО ІР 

ЕИО 

По всем вопросам обращаться : 
Москва , т.366-25-02, А.Колесов 
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іС^джьш, кто хотя бы в малой степени 
связан с миром компьютеров , знает , что 
изменения в этой области человеческой 
деятельности происходят с поистине 
космической скоростью . Прекрасную 
возможность проследить за этими 
изменениями , быть на острие передовых 
компьютерных технологий , охватить разом 
новинки сотен и тысяч фирм предоставляют 
международные выставки , многие из которых 
являются традиционными . Выставка СеВІТ в 
ФРГ — одна из них . Корреспондент 
КомпьютерПресс был свидетелем этого 
значительного события , и сегодня — рассказ о 
СеВІТ' 91. 


СеВІТ'91 


Ежегодно сотни тысяч посетителей устремляются на 
крупнейшую в мире компьютерную выставку СеВІТ, 
которая проходит весной в Ганновере (ФРГ). В этом 
году выставка проводилась с 13 по 20 марта. По раз- 
маху и количеству представленных на ней фирм она в 
пять раз превзошла своего ближайшего конкурента — 
осеннюю выставку Сотсіех/Раіі в Лас-Вегасе (США). 

В СеВІТ'91 приняли участие 4568 фирм из 45 стран 
мира, которые представили полный спектр современ- 
ного программного и аппаратного обеспечения. Вся 
выставка, разместившаяся в 17 павильонах общей пло- 
щадью 390 тыс. кв. м, была организована по 11 основ- 
ным разделам: 

— информационные системы; 

— телекоммуникации; 

— безопасность и надежность; 

— программное обеспечение и базы данных; 

— периферийное оборудование; 

— автоматизация учреждений; 

— банковские системы; 

— микрокомпьютеры; 

— сети; 

— автоматизированные системы; 

— обучающие системы. 

Многие ведущие фирмы представляли свои изделия 
сразу по нескольким направлениям. Например, фирма 
НедѵІеИ-Раскагсі демонстрировала свои мини- и микро- 
ЭВМ, периферийное оборудование, программное обес- 


печение и сетевые разработки, фирма 5Нагр — кон- 
торское оборудование, портативные компьютеры, ла- 
зерные принтеры и т.п. 

В отличие от предыдущих выставок на СеВІТ'91 до- 
статочно широко были представлены советские фир- 
мы. Здесь можно было увидеть стенды “Параграфа", 
“Интермикро", “Аквариуса (А5І)" и некоторых других 
совместных и государственных предприятий. Так, на 
стенде А5І демонстрировались новые разработки фир- 
мы, такие, как портативный компьютер типа 
“поіеЪоок" на базе 386 процессора, рабочая станция 
для локальных сетей, не имеющая системного блока, 
персональный компьютер на базе 286 процессора со 
значительно уменьшенным и более привлекательным, 
по сравнению с моделью А5І-286/12, системным бло- 
ком. Особое внимание привлекла модель новой и, 
безусловно, перспективной серии компьютеров А5І 
Мееаііпе для процессоров 386 и 486. 

В работе выставки принял участие чемпион мира по 
шахматам Гарри Каспаров, который на стенде фирмы 
1ВМ провел несколько партий с новой версией извест- 
ной шахматной программы Оеер ТНои^Ы — Беёр 
ТНои^М 2. 

Особый интерес у посетителей вызвал “говорящий" 
компьютер фирмы ТозЫЬа. С помощью голосового ин- 
терфейса и забавной рожицы на экране компьютера 
создавалась атмосфера общения с живым существом. 
Компьютер мог сколь угодно долго поддерживать раз- 
говор на английском языке, причем практически на 
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любую тему, отпускать достаточно тонкие шутки и, 
что поражало посетителей более всего, запоминать го- 
лос говорящего с ним человека. Стоило лишь однажды 
представиться ему, и компьютер даже через несколько 
дней мог отличить ваш голос от многих других голо- 
сов: после вашего приветствия следовало четкое “Неііо 
Ѵа1егу“ (если вы представились как Ѵаіегу). Особенно 
удивительна была скорость, с которой выполнялась ге- 
нерация ответов машины, что говорит об исключи- 
тельной эффективности алгоритмов обработки речи и 
нахождения адекватных путей ведения диалога. 

Конечно же, рассказать обо всех событиях и экспо- 
натах выставки СеВІТ'91 невозможно, поэтому мы ос- 
тановимся лишь на некоторых из них. 

Фирма НешІеН-Раскагё демонстрировала свой но- 
вый лазерный принтер ЬазегЛеІ ІІІЗі. Этот принтер 
продолжает линию принтеров Ьазег\ІеІ III, что позво- 
ляет практически без дополнительного чтения руково- 
дства приступить к работе, если до этого вы были зна- 
комы с Ьазепіеі III или Ьазегіеі НЮ. Это обусловлено 
единообразием конструкции передней панели управле- 
ния и командами, которые появляются на жидкокрис- 
таллическом экране. 

Особенностью Ьазегіеі ІІІЗі, безусловно, является 
скорость его работы — 16 страниц в минуту при фор- 
мате листа А4 и 17 страниц при формате Ьеііег. Такая 
высокая скорость обеспечивается благодаря наличию в 
Ьазепіеі ІІІЗі форматера страниц на базе КІЗС-процес- 
сора. Принтер имеет два поддона для бумаги на 500 
листов формата А4 каждый, а также дополнительное 
устройство для подачи конвертов (емкость 100 шт.). 

Разрешающая способность принтера Ьа$ег\Іе( ІІІЗі 
по-прежнему равна 300 точкам на дюйм, однако за 
счет использования технологии улучшения разрешаю- 
щей способности Кезоіиііоп ЕпНапсетепІ, которая ста- 
ла применяться фирмой Не\ѵ1еІ!-Раскагс1 в принтерах 
серии III, а также использования специального мелко- 
зернистого тонерного порошка, разрешение Ьазеічіеі 
ІІІЗі сравнимо с качеством печати уровня 600 точек на 
дюйм. 

В стандартной конфигурации принтер поставляется 
с памятью 2 Мбайта, однако наличие 4 разъемов для 
установки дополнительных блоков памяти позволяет 
довести ее общую емкость до значительной величины 
в 17 Мбайт. 

По словам специалистов фирмы Не\ѵІеІІ-Раскагс1, 
все эти характеристики, а также возможность установ- 
ки дополнительных (опциональных) сетевых интер- 
фейсов типа АрреІТаІк, ЕіНегпеІ и Токеп Кіп^ делают 
лазерный принтер Еазегіеі ІІІЗі идеальным печатаю- 
щим устройством для коллективного использования в 
среде локальных сетей. 

Фирма Зіаг Місгопісз также представила свой новый 
лазерный принтер ЕазегРгіпІег 4, предназначенный в 
основном дл» использования в качестве персонального 
печатающего устройства. Его разрешающая способ- 
ность в 300 точек на дюйм, достаточно удобная па- 
нель управления и скорость работы — 4 страницы в 
минуту вполне соответствуют принтерам этого класса. 


Следует отметить, что, согласно утверждению пред- 
ставителей фирмы, ЬазегРгіпіег 4 обладает высокой 
надежностью и долговечностью, благодаря чему срок 
его службы составляет 150 тыс. страниц, или 5 лет. 
Однако основная часть экспозиции Зіаг Місгопісз была 
посвящена матричным принтерам — традиционно 
сильной стороне фирмы. На стенде фирмы были пред- 
ставлены новые модели 9-игольчатых принтеров ТА - 
200, 2А-250, ЬС-20 и ЬС-200, а также 24-игольчатые 
и цветные принтеры 1X24-200, 1X24-200 Соіоиг, 
ХВ24-200 и ХВ24-250. 

Фирма ЗНагр продемонстрировала одну из своих по- 
следних разработок в области компьютеров типа “за- 
писная книжка 44 (поІеЬобк) — модель РС-6220 с про- 
цессором 80С286 (тактовая частота 12 МГц). Этот 
компьютер имеет отличный жидкокристаллический 
ѴСА-дисплей, который построен с применением но- 
вейшей технологии тройного супертвистирования, не- 
большой вес — 2 кг и компактный корпус размером 
279x216x34 мм. РС-6220 имеет встроенный жесткий 
диск на 20 Мбайт с временем доступа 23 мс, опера- 
тивную память емкостью 1 Мбайт с возможностью 
расширения до 3 Мбайт и ПЗУ, которое содержит 
операционную систему МЗЮОЗ 4.01 и известную про- 
грамму Ьар-Ьіпк для обмена данными между компью- 
терами. Компьютер обладает широкой гаммой допол- 
нительных устройств, таких, как блок с цифровой 
клавиатурой, накопитель 3-дюймовых гибких дисков 
емкостью 1.44 Мбайта с портами для подключения 5- 
дюймового накопителя гибких дисков и расширенной 
клавиатуры стандарта ІВМ, а также блок расширения 
с адаптером ѴСА-дисплея, платой модем/факс и мес- 
тами для установки 2 плат стандарта АТ. Если учесть, 
что с дополнительным блоком для батарей РС-6220 
может работать до 5 часов, становится понятным, что 
фирма ЗНагр приподнесла хороший подарок пользова- 
телям, нуждающимся в легком и в то же время доста- 
точно мощном переносном компьютере. 

На стенде фирмы Ніоѵеіі были представлены новые 
версии популярной сетевой операционной системы 
1Меі\Ѵаге: ЫеІ\Ѵаге 286 2.2 и Ыеі\Ѵаге 386 3.11. Доста- 
точно впечатляюще выглядела демонстрация работы 
ЫеІ\Ѵаге 386 3.11 для 250 рабочих станций — одного 
из новшеств этой версии по сравнению с предыдущей 
версией. 

В заключение хотелось бы отметить, что благодаря 
стремительному развитию рынка восточноевропейских 
стран, в том числе Советского Союза, выставка СеВІТ 
приобретает особое значение. Многие из их фирм ус- 
тремляются именно на СеВІТ в поиске выгодных 
контрактов. Это позволяет предположить, что в бли- 
жайшее время Ганновер станет именно тем местом, 
где фирмы Запада и Востока смогут способствовать 
столь необходимым экономическим реформам в вос- 
точноевропейских странах, которые невозможны без 
использования передовых компьютерных технологий. 

В . Миропольский 
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ВЗГЛЯД В ПРОШЛОЕ , 
ПЕРСПЕКТИВЫ БУДУЩЕГО 


С-егодня мы публикуем выступление 
Питера Нортона на открытии 
выставки Сотіек' 91 , состоявшемся 
в Москве 8 апреля 1991 года. 


Введение 

Удивлен сходством той ситуации, в которой вы сегод- 
ня находитесь, с тем, что мне пришлось самому испы- 
тать в начале семидесятых годов. 

В Советском Союзе происходят большие перемены, 
и вместе с ними у людей возникает все больше воз- 
можностей начать свой бизнес. Надежды возлагаются 
на способных людей с их прекрасными идеями, а так- 
же на большое количество потенциальных покупате- 
лей с их неудовлетворенными потребностями. 

И успех возможен как для малых предприятий с до- 
вольно скромными ресурсами, так и для большого биз- 
неса. 

Советские предприниматели имеют сейчас те же за- 
манчивые перспективы, что и я в свое время, или мои 
коллеги — Митч Кэйпор, который написал Ьоіиз 
1-2-3, или Стив Джобс, основавший Арріе Сотриіегз, 
или Билл Гейтс, президент МісгозоН — и сотни дру- 
гих людей, ставших первопроходцами американской 
индустрии микрокомпьютеров. 

Когда я начал заниматься программированием в на- 
чале семидесятых, персональных компьютеров было 
очень мало. Появление ІВМ РС в 1982 году спосо- 
бствовало быстрому росту отрасли. Большая часть 
инфраструктуры, которую мы сейчас имеем в США с 
ее доступом к капиталу, каналами распространения, 
образованием, и так далее, начала формироваться 
именно в то время. 

Мы знали, что нам нужно сделать, чтобы решить те 
сложные задачи, которые мы ставили перед собой, но 
вряд ли кто-нибудь представлял себе, к каким гран- 
диозным результатам приведет развитие новой индуст- 
рии. 


У вас уже есть то, чего не было у нас, то, что мо- 
жет быть очень ценным на этом этапе развития совет- 
ской экономики. У вас накоплен колоссальный опыт в 
импровизации, в умении работать только с тем, что у 
вас есть под рукой, в способности полагаться на самих 
себя. У вас есть то, что называется “житейской муд- 
ростью“. Знание, как извлечь выгоду из того, что есть, 
и выйти из любой ситуации — это отличный опыт, 
который можно с успехом использовать, чтобы от- 
крыть свое дело. 

И поскольку история повторяется, я бы хотел поде- 
литься с вами своим опытом. 

Начало 

Когда вы начинаете свое дело, вам надо быть готовым 
к тому, чтобы засучить рукава и делать все самостоя- 
тельно. Когда я написал свою первую программу 
“ІІпЕгазе 44 , практически никакой помощи со стороны 
не было, чтобы попытаться получить какую-то выгоду 
от существования этой программы. У меня не было ни 
опыта, ни образования в области бизнеса. Все, что у 
меня было — мои сбережения. Но я чувствовал, что 
сделал отличную программу, и мне не хотелось оста- 
навливаться. И я хотел делать все сам. 

Заказы на первые программы в 1982 году я выпол- 
нял у себя дома, используя персональный компьютер 
для копирования программ на гибкие диски, а затем 
шел на почту и отправлял их своим заказчикам. 

Создание программы: первый раунд 

Создание хорошей программы — трудное дело. Су- 
ществует два подхода, которые вы можете при этом 
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использовать. Оба могут быть успешны. Все зависит от 
обстоятельств. 

Подход первый — это полагаться во всем на себя. 
Второй — полагаться на вашего заказчика. 

Если вы верите себе, если интуиция подсказывает 
вам, что вы знаете, что может понадобиться лю- 


дям — следуйте вашей интуиции и не слушайте, 
что вам говорят со всех сторон. Если интуиция вас не 
обманывает, тогда, положившись на себя. Вы непре- 
менно придете к успеху. 

Второй подход — положиться на заказчика. Спро- 
сите ваших потенциальных пользователей, что им 
нужно. Вы узнаете много интересного, поговорив с 
каждым из них. 

Преимущество первого подхода заключается в том, 
что у вас появляется хорошая интуиция, некое виде- 
ние будущего — вы можете знать, что пользователям 
понадобится завтра, в то время, как сами пользователи 
могут этого не знать. Очень часто пользователей бе- 
спокоят проблемы вчерашнего дня, а главная задача 
для нас, бизнесменов — создавать программы, кото- 
рые будут нужны завтра. 

Например, в 1982 году, когда я написал свою пер- 
вую программу “ІІпЕгазе 44 , чтобы восстановить слу- 


чайно стертый файл, никому такие программы, каза- 
лось, были не нужны. Но я-то знал, какую цен- 
ность для меня и для моих друзей представляет на- 
писанная мною программа. Спустя некоторое время, 
когда все поняли, насколько важно иметь возмож- 
ность восстановить утерянные данные, “ІІпЕгазе 44 
фактически сформировала новый 
сектор рынка программных 
средств для РС, который называ- 
ется сектором сервисных про- 
грамм. 

Преимущество второго подхода в 
том, что вы узнаете, что представля- 
ет собой ваш потенциальный заказ- 
чик, каковы его потребности. Вы уз- 
наете мнения многих людей. Такой 
подход мы называем “управляемый 
пользователь 44 . 

Оба этих подхода могут рабо- 
тать. Вам надо понять, какой из 
них больше подходит к опреде- 
ленной ситуации. 

Создание программы: 
второй раунд 

Совершенно очевидно, что создание 
одной программы не может обеспе- 
чить длительный успех. Параллель- 
но с разработкой первого продукта 
необходимо думать о перспективе. 
Существует два способа двигаться 
дальше. Первый — улучшить су- 
ществующий продукт, второй — со- 
здать новый. 

Первая опция: усовершенствовать 
продукт. Создание новой версии су- 
ществующего продукта — если он 
пользуется успехом — одна из наи- 
более важных конкурентоспособных 
характеристик, которую вы можете 
использовать в условиях свободного предприниматель- 
ства. Во-первых, пользователь уже имеет ваш продукт, 
и вам не потребуется прилагать так же много усилий 
для продажи новой версии, как для продажи пред- 
шествующей. Он вложил время и деньги в изучение 
программы и знаком с ней. Во-вторых, вы используете 
созданный продукт и добавляете к нему новые функ- 
ции. Это гораздо быстрее и дешевле, чем начинать с 
нуля. 

Мы не раз обновляли и усовершенствовали наши 
сервисные программы, Каждагі новая версия предстает 
более мощной, качественной, функционально насы- 
щенной. Фактически только в прошлом году мы вы- 
пустили Ыогіоп Шіііиііез 5.0. Это пятая большая вер- 
сия — вместе с другими программами — той самой 
первой “ІІпЕгазе 44 , которую я создал в 1982 году. А 
что касается Ыогіоп Соттапбег — мы сделали уже 
третью версию. 


В день открытия выставки СотІек-91 прошла презентация шес- 
ти русифицированных продуктов фирмы Зутапіес. На ней высту- 
пили П. Нортон — сейчас он входит в совет директоров фирмы 
Зутапіес и С.Тирелл — менеджер по Восточной Европе и СССР. 

Сегодня Зутапіес является одной из крупнейших компаний США , 
число ее сотрудников приближается к 600. С момента создания 
фирма активно развивала международную торговлю. Ее програм- 
мные продукты переведены на 11 языков. 

В 1990 году произошло слияние фирм Реіег ИоПоп Сотрийп% и 
Зутапіес. Это позволило объединить колоссальный творческий по- 
тенциал программистов первой с богатым опытом производства 
и сбыта программных продуктов , накопленным второй из фирм. 
Сейчас Зутапіес имеет вспомогательные фирмы в 7 странах ми- 
ра , сотрудничая , кроме того , со всеми крупнейшими странами ми- 
ра. Фирма активно работает над установлением деловых отно- 
шений с Россией и другими нашими республиками , странами Цен- 
тральной Европы и рассматривает это как долгосрочную работу, 
направленную в будущее. По словам Питера Нортона, "надежды 
возлагаются на способных людей с их прекрасными идеями, а 
также на большое количество потенциальных покупателей с их 
неудовлетворенными потребностями". 

По мнению фирмы, успех компьютеризации в нашей стране тесно 
связан с тем, как будет развиваться производство компьютеров 
и как будет расти количество фирм, работающих в области ин- 
форматики. Представители Зутапіес высказали надежду на то, 
что мы добьемся успеха в этой области. 
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Так что, как вы сами видите, усовершенствование 
продукта, который хорошо зарекомендовал себя, мо- 
жет быть весьма прибыльным делом. 

Вторая опция: создать новый продукт. Вы можете 
создать продукт, которого вообще нет на рынке, или 
найти хороший продукт, который, несмотря на конку- 
ренцию, не обновляется производителем. И лучшее, 
что вы можете сделать в этой ситуации — предложить 
лучшую версию конкурентного продукта, а не 
создавать полностью новый. 

Мы, специалисты по высоким технологиям, 
зачастую сосредоточиваемся только на самых 
современных разработках, охотимся за наибо- 
лее совершенными продуктами и восхищаемся 
новыми технологиями. Но, как я узнал, Ваше- 
го пользователя просто так не вдохновишь. 

Бизнесмену нужно знать, что большинство 
пользователей персональных компьютеров вы- 
полняют общие задачи и используют базовые 
продукты типа Ьоіиз 1-2-3. У них нет ни вре- 
мени, ни желания, чтобы перейти на исполь- 
зование современной технологии. Помните об 
этом при создании нового продукта. 

Интеллектуальная собственность 

Это еще одна тема, о которой в, последнее вре- 
мя говорят все больше и больше. В США этот 
вопрос также весьма активно обсуждается — 
особенно применительно к программному обеспече- 
нию. Я знаю, что многие из вас имеют копии некото- 
рых моих программ, и очень приятно видеть, что они 
так популярны здесь. 

Когда я начинаю распространять продукт, я хочу, 
чтобы мои пользователи могли извлечь из него макси- 
мальную пользу. Но это означает, что им нужно руко- 
водство по эксплуатации, сопровождающее программу. 
Им надо попробовать поработать со всеми функциями 
и, может быть, если им понадобится дополнительная 
помощь, они обратятся в отдел поддержки пользовате- 
лей, чтобы получить дополнительную подготовку. Всем 
нам, представителям компьютерной индустрии, выгод- 
но поддерживать права интеллектуальной собственнос- 
ти, защитить свой бизнес. 

Маркетинг и продажа: 
больше, чем половина задачи 

Создание хороших программ — это только часть той 
сложной задачи, с которой мне пришлось столкнуться 
после того, как я написал “ІІпЕгазе". Одна из любо- 
пытных особенностей свободной экономики в том, что 
маркетинг и продажа продукта — это более, чем пол- 
задачи. У нас даже поговорка есть, что самый пре- 
красный программный продукт не сможет продать се- 
бя в условиях свободного предпринимательства. 

Когда я предложил свою первую программу, я при- 
лагал массу усилий, чтобы довести ее до пользовате- 
лей. К тому времени я уже несколько лет работал с 
компьютерами, но только тогда начал использовать 
ІВМ РС, распространяемый на коммерческой основе. 


Как только я научился работать с компьютером, я ре- 
шил поделиться своими навыками со всеми пользова- 
телями посредством распространения информационно- 
го листка. Я назвал этот листок “шпаргалкой". 

Шпаргалки содержали много практической инфор- 
мации и имели, конечно же, рекламу моих собствен- 
ных продуктов на обратной стороне каждого листка. 
Каждые два месяца я посылал мои шпаргалки по поч- 


те в компьютерные клубы и магазины — например. 
Сотри ІегЬапсІ. Главной целью было сделать мои про- 
граммы известными и внушить пользователям доверие 
к ним. 

Важность маркетинга поистине трудно переоценить. 
Я использовал еще одно средство для популяризации 
моих продуктов. Я понял, что, в общем, технологичес- 
ким продуктам недостает человеческого тепла. И я хо- 
тел, чтобы мой продукт имел эти человеческие черты, 
поэтому я поместил свое имя на него, назвал своим 
именем компанию, а на коробках начали печатать 
мои фотографии. 

Пользователь как бы получает сообщение: “За этой 
программой стоит не безликая корпорация, а реаль- 
ный человек, который знает, что делает". 

Это всего лишь два примера использования мною 
средств для целей маркетинга. Эти средства так же за- 
висят от конкретной ситуации и от ваших собствен- 
ных возможностей, конечно. Оказалось, что я могу хо- 
рошо объяснить пользователю-новичку технические 
аспекты программы — вероятно, потому, что я хорошо 
помню свой собственный опыт на ІВМ РС. И писать 
те самые шпаргалки было для меня вполне естествен- 
ным занятием. 

Управление бизнесом: 
просто технических знаний 
недостаточно 

Я говорил немного о важности маркетинга и продаж, 
что подвело меня к другой теме: важность разумного 
управления бизнесом. 


Выступление Питера Нортона на презентации продуктов 
фирмы 8утап(ес 

Спасибо , я очень рад присутствовать на Сотіек . Это 
очень интересное время — время моего приезда в Совет- 
ский Союз . Это время больших перемен и больших воз- 
можностей. 

Мы очень рады принять участие в развитии компьютер- 
ных технологий , в частности программного обеспечения 
в СССР. 

Я очень рад сегодня встретится с вами , и горд тем , что 
мы представляем русские версии наших программных про- 
дуктов советским программистам. 

Счастлив приветствовать вас на СотІек-9І и внести 
свой вклад в это новое начинание. 
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ВЗГЛЯД В ПРОШЛОЕ, ПЕРСПЕКТИВЫ БУДУЩЕГО 


Выступление Санни Тирелл на презентации продуктов 
фирмы Зутапіес 

Год назад фирма Зутапіес приняла участие в первой меж- 
дународной выставке Сотіек-90. Тогда многие фирмы при- 
ехали , чтобы посмотреть , какова ситуация на советском 
рынке компьютерных технологий . 

И сегодня , год спустя , мы очень горды , что можем пред- 
ставить шесть продуктов Зутапіес, переведенных на рус- 
ский язык . Программы , которые мы выбрали для рас- 
пространения в Советском Союзе , следующие: ЫоПоп 
Соттапсіег, ИоПоп ШіШез, Ыогіоп Васкир у Ыогіоп 
АпІіѴігиз, Тіте Ыпе и ( }&А . Мы хотели бы , чтобы эти 
продукты были у советского пользователя , поэтому они 
будут продаваться за рубли . 

Это самая большая страна из всех , где мы когда-либо ра- 
ботали. И чтобы работа была успешной , мы установили 
отношения с тремя квалифицированными дистрибьюто- 
рами: СП “Компьютерные технологии СП “Диалог“ при 
МИФИ и ГИЦ “ЦЕНТ РПРОГРАММСИСТЕМ“. 

Наши дистрибьюторы позволят нам иметь сеть диле- 
ров , ориентированных на конечного пользователя. Под- 
держка пользователя , предоставляемая ими , будет вклю- 
чать постоянно действующую горячую линию, консуль- 
тации и проведение семинаров. Кроме того , дистрибью- 
торы позволят надежно и качественно обслуживать 
пользователей и снабжать их последними версиями паке- 
тов. Наконец , дистрибьюторы будут обучать пользова- 
телей работе со всеми видами наших продуктов. 

На базе СП “Компьютерные технологии “ создается клуб 
пользователей Питера Нортона , который позволит по- 
купателям программ обмениваться информацией и идея- 
ми. 

Кроме того , есть желание создать клуб пользователей 
пакета Тіте Ыпе у но детали этого проекта пока неясны. 
Часть доходов от распространения продукции Зутапіес в 
СССР пойдет на благотворительные цели. Десять рублей 
с каждой проданной копии программы будут направлять- 
ся на благотворительный счет “Огонек- АнтиСП И Д“ для 
финансирования закупок одноразового медицинского обо- 
рудования. 


Когда я основал Реіег Ыогіоп Сотриііп^ в 1982 году, 
у меня не было никакого коммерческого образования. 
Я занимался программированием для аэрокосмической 
промышленности в Южной Калифорнии. Я имел ма- 
тематическое образование, накопил приличные знания 
в информатике. Но у меня не было ни малейшего 
представления о том, как начать свой бизнес и какие 
надо прилагать усилия, чтобы он был успешным. 

Мне приходилось одновременно изучать теорию и 
практику бизнеса, надо было знать все: от бухгалтерии 
и управления персоналом до маркетинга и продаж. 


Свое образование в области управления я 
получал “на работе 44 , действуя методом проб и 
ошибок, чтобы понять, что работает и что нет. 
Я читал все, что попадало мне в руки — 
Рогіипе, РогЬез, Визіпезз дѵеек, и вообще все, 
что тогда было написано о, бизнесе. И говорил, 
с кем только мог. 

Мораль: учитесь управлять — учитесь где 
можете и как можете. 

Оценка своей силы 

Небольшие компании обычно основываются 
умными, талантливыми и опытными людьми. 
И мне очень приятно видеть их сегодня в этом 
зале. 

Я бы хотел посоветовать вам реально оце- 
нить свои силы и найти людей, которые до- 
полнили бы их опытом в других областях. 

И когда вы найдете этих талантливых лю- 
дей, предоставьте им возможность использо- 
вать этот опыт. 

В некоторых случаях, развивая это направ- 
ление, можно соединить опыт двух компаний. 
В середине прошлого года я объединил свою 
компанию с фирмой Зутапііс. Мы объединили 
опыт создания сервисных^ программ и хорошо 
действующую торговую сеть. Зутапііс выпус- 
кает и другие программные продукты — уп- 
равление проектами, коммуникации, языки 
программирования. 

Оценка возможностей компании не менее 
важна, чем оценка возможностей каждого от- 
дельного человека. 

Развитие технологий 

Шесть лет назад я говорил в Болгарии и по- 
вторю сейчас: использование персональных 

компьютеров сулит большую выгоду малому и 
среднему предпринимательству, но предприни- 
мателям не надо иметь обязательно 386 или 
486 микропроцессоры, которые так нужны 
нам — специалистам в области технологий. 

Бизнесмен может использовать доступную, 
простую в эксплуатации и сравнительно деше- 
вую систему. Вы можете значительно улуч- 
шить свою производительность при минималь- 
ных затратах, приобретя компьютер на 286 
микропроцессоре. 

Заключение 

В заключение, делая вывод из собственного опыта, я 
хотел бы сказать вам, что если вы действительно за- 
интересованы, готовы идти на риск, если вы изобрета- 
тельны — вы добьетесь успеха. 

Я высоко ценю Ваше умение импровизации, умение 
использовать жизненный опыт. Это очень важные ка- 
чества для того, чтобы начать бизнес, чтобы стать 
преуспевающим предпринимателем. 
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8 апреля 1991 года корпорация Іпіеі подписала свои 
первые дистрибьюторские соглашения в СССР. Два 
совместных предприятия, уже достаточно хорошо за- 
рекомендовавшие себя на советском рынке, “Компью- 
терные технологии 14 (КоТ) и “Диалог 11 будут высту- 
пать в качестве официальных дистрибьюторов продук- 
ции компании Іпіеі. Соглашения вступают в силу с 
момента подписания. 

“Эти компании обладают всем, что необходимо 
“Интелу 11 , — сказал Бени Гинман, Региональный Ме- 
неджер по СССР. — “Они имеют достаточный опыт и 
развитую сеть, необходимую для удовлетворения рас- 
тущих потребностей в автоматизации учрежденческой 
деятельности и запросов изготовителей комплексного 
оборудования 11 . 

“Наша политика в Советском Союзе ничем не от- 
личается от той, которую мы проводим в других стра- 
нах. В ее основе лежит комплексный подход, который 
предусматривает продажу нашего оборудования на 
разных уровнях интеграции. В настоящее время мы 
ведем переговоры с потенциальными дистрибьюторами 
с целью продажи наших компонентов непосредственно 
изготовителям комплексного оборудования 11 , — доба- 
вил Гинман. 

Компания также объявила о своем намерении от- 
крыть в этом году свой офис в Москве, где будут рабо- 
тать как американские, так и советские специалисты. 


8 апреля 1991 года в Москве на 
международной выставке “ КОМТЕК-9 Г ‘ 
проходила пресс-конференция фсемирно 
известной компании Іпіеі Мы 
представляем вашему вниманию 
материалы пресс-конференции, а также 
тексты выступлений директора по 
стратегическим проектам фирмы 
Дмитрия Ротова и регионального 
менеджера Бенни Гинмана. 


Іпіеі В СССР 


Корпорация Іпіеі 

и ее стратегия в Советском Союзе 

Дмитрий Ротов 

Дамы и господа, 

Корпорация Іпіеі была основана в калифорнийской 
“Кремниевой долине 8 * * 11 в 1968 году и добилась успеха 
благодаря изобретению и производству целого ряда 
электронных компонентов, используемых сейчас в 
каждом компьютере. Среди изобретений компании 
Іпіеі, например, динамическое оперативное запомина- 
ющее устройство (ДОЗУ), стираемое перепрограмми- 
руемое постоянное запоминающее устройство 
(СППЗУ), а также первый микропроцессор. 

В настоящее время наша компания известна как 
производитель микропроцессоров 8086, 80286, Іпіеі 
386 (ТМ), а также Іпіеі 486 (ТМ), которые поистине 
являются “сердцем 11 персональных компьютеров, сов- 
местимых с ІВМ. По последним подсчетам, 80 милли- 
онов персональных компьютеров во всем мире исполь- 
зуют микропроцессоры, созданные по технологии Іпіеі. 
Эти микроЭВМ производятся тысячами компаний по 
всему миру: в США, Европе, Японии, Корее, Тайване, 
а также в Советском Союзе. Компьютеры компании 
Іпіеі обрабатывают больше программ, чем какие-либо 
другие ЭВМ. Сегодня Іпіеі сохраняет свое технологи- 
ческое лидерство в области микроэлектроники и явля- 




КомпьютерПресс 5'91 



70 


Іпіеі В СССР 


КомпьютерПресс: Налагает ли КОКОМ 
какие-нибудь ограничения на продажу про- 
дукции Іпіеі в Советском Союзе? 

Интел : Не такие строгие, как раньше. Уже 
сейчас снят запрет на все микрокомпьютер- 
ные платформы на базе І386/33 ОХ и про- 
граммное обеспечение. Экспорт і486 пока что 
невозможен без лицензии. 

КП: Будете ли вы продавать свои изделия 
за рубли? 

И: По крайней мере в ближайшее время — 
только за валюту. 


ется крупнейшим поставщиком компонентов для мик- 
роЭВМ, модулей и систем, таким образом предлагая 
изделия всех уровней интеграции. Традиционно ком- 
поненты составляют 70% нашего бизнеса. 

Наша основная цель в Советском Союзе заключает- 
ся в обеспечении доступа растущей советской элек- 
тронной промышленности к нашим компонентам и из- 
делиям системного уровня. Относительно компонент- 
ной стороны нашего бизнеса я должен сказать, что на 
нас произвели огромное впечатление возможности со- 
ветской промышленности. За последние несколько ме- 
сяцев мы были на многих советских электронных заво- 
дах, ознакомились с их техническими и деловыми воз- 
можностями, и нам стало совершенно ясно, что, имея 
доступ к микропроцессорам Іпіеі и другим ключевым 
компонентам, они смогут наладить производство пер- 
сональных компьютеров на своей территории. 

Доступ к широкому ассортименту продукции Іпіеі 
обеспечит рост советской компьютерной промышлен- 
ности и позволит ей значительно увеличить производ- 
ство микроЭВМ. Мы намерены содействовать этому 
процессу, организовав обучение советских специалис.- 
тов для успешного использования наших компонентов. 
Нам также хотелось бы помочь другим отраслям со- 
ветской промышленности в разработке и применении 
других изделий (таких как, например, микроконтрол- 
леры) в производимом ими промышленном оборудова- 
нии. Во многих случаях использование одного един- 
ственного микроконтроллера стоимостью менее 5 дол- 
ларов может сэкономить механические части ценой в 
несколько сот долларов. Это также обеспечит надеж- 
ность, высокую производительность и позволит сни- 
зить цену на такое сложное промышленное оборудова- 
ние, как, например фрезерный станок. 

И наконец, наши 32-разрядные процессоры се- 
мейств 386 и 486 позволят советской электронной про- 
мышленности отказаться от уже устаревших на Западе 
16-разрядных микроЭВМ и, таким образом, выйти на 
качественно новый уровень. Мы также предоставим 
Советскому Союзу наши 32-разрядные изделия в сис- 
темной форме, что будет способствовать переходу к 
32-разрядным настольным комьютерам. 


Неотъемлемой частью стратегии компании Іпіеі яв- 
ляется поставка продукции всех уровней интеграции. 
Многим заказчикам на Западе необходима наша про- 
дукция (или платы, или изделия системного уровня) с 
тем, чтобы выйти на рынок быстрее, чем если бы они 
разрабатывали и производили ее сами. Наши послед- 
ние достижения в области компьютерной технологии 
предоставляют программистам и пользователям воз- 
можность начать работать на самом современном обо- 
рудовании. 

Первое дистрибьюторское соглашение 
Іпіеі в СССР 

Бени Гинман 

Дамы и господа, 

Для меня и моей компании большая честь присут- 
ствовать здесь сегодня и сообщить вам о первом зна- 
чительном шаге корпорации Іпіеі на пути организации 
торговой сети и системы обслуживания, предназначен- 
ных для потенциальных заказчиков в СССР. Для ком- 
пании Іпіеі выход на новый рынок исторически всегда 
означал поиск дистрибьютора. Поскольку 30-40% про- 
даж компании осуществляется через официальных 
дистрибьюторов, Іпіеі уделяет отношениям с ними 


КомпьютерПресс: Расскажите вкратце о 
вашем новом кристалле І586 и о том, когда 
вы собираетесь приступить к выпуску этого 
процессора. 

Интел: Вообще, мы не уполномочены да- 
вать комментарии по этому поводу, но можем 
сказать, что при степени интеграции около 
одного миллиона транзисторов, микропроцес- 
сор 80586 будет работать примерно в 4-5 раз 
быстрее своего предшественника. 

КП: Буде;г ли фирма продолжать линию 
КІ8С-процессоров? 

И: Обязательно, причем уже в этом году 
было объявлено о начале производства двух 
новых микропроцессоров, совместимых с І860. 

КП: Не чувствуете ли вы жаркое дыхание 
догоняющих вас конкурентов, таких, как, на- 
пример компания Моіогоіа? 

И: В сфере микропроцессоров — нет! Наша 
фирма является сегодня признанным лидером 
как с точки зрения концептуально новых раз- 
работок, так и по объемам производства. А к 
середине 90-х марка Іпіеі будет стоять на че- 
тырех из каждых пяти выпускаемых во всем 
мире микропроцессоров. 
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первостепенное значение. Немало времени и сил ухо- 
дит на формирование дистрибьюторской сети, так же 
как и на обеспечение необходимого уровня профессио- 
нализма персонала. Именно поэтому в каждой стране 
существует ограниченное число дистрибьюторов. И 
для компании Іпіеі, и для ее дистрибьюторов установ- 
ление взаимоотношений является задачей огромной 
важности, так как это означает формирование сети 
заказчиков. Это объясняет тот факт, что многие из на- 
ших европейских дистрибьюторов являются нашими 
партнерами с момента зарождения Іпіеі. Компания 
Іпіеі была образована в 1968 году, и уже в 1969 году 
был назначен наш первый европейский дистрибьютор 
в Швеции. Как вы понимаете, за это время мы хорошо 
узнали наших дистрибьюторов, как и они нас, нашу 
продукцию и нашу стратегию. 

Вы, по всей видимости, недоумеваете, зачем я вам 
все это рассказываю? 

А причина вот в чем: я хочу, чтобы вы помнили, 
покидая этот зал, что дистрибьютор Іпіеі — это неот- 
делимая часть нашей компании. Они члены нашей 
“семьи 44 . 

Наши дистрибьюторы в Советском Союзе не явля- 
ются исключением. Они примут участие в наших об- 
разовательных программах и курсах переподготовки. 
Они будут осуществлять свою деятельность на том же 
качественном уровне, что и другие наши дистрибьюто- 
ры. Это означает, что наши клиенты в Советском Со- 
юзе будут получать столь же высококачественные про- 
дукцию и обслуживание, как и их коллеги в Европе, 
Соединенных Штатах Америки, Японии и других 
странах. 

Дамы и господа, я чрезвычайно рад представить вам 
наших первых двух дистрибьюторов в Советском Сою- 


зе — СП “Диалог 44 и “Компьютерные технологии 44 
(КоТ). Обе компании являются советско-американски- 
ми совместными предприятиями. СП “Диалог 44 было 
образовано в 1987 году и сейчас имеет более 80 фили- 
алов с количеством сотрудников, превышающим 1000 
человек. “КоТ 44 является очень молодой компанией, 
образованной в 1990 году. С американской стороны ее 
учредитель — компания “Мерисел 44 , крупнейший в 
мире дистрибьютор компонентов для микроЭВМ. 

Их обучение в качестве наших партнеров по бизне- 
су началось в январе этого года и будет продолжаться 
всегда. 

Эти дистрибьюторы будут заниматься продажей из- 
делий Іпіеі на уровне 32-разрядных микрокомпьютер- 
ных платформ и систем высокой степени интеграции. 
Помимо плат и блоков они предложат другие изделия 
Іпіеі, расширяющие возможности ПЭВМ, такие, как 
математические сопроцессоры Іпіеі 386 (ТМ), модемы 
и системы факсимальной связи. 

В настоящее время в Европе действуют 48 дистри- 
бьюторов Іпіеі. Сегодняшнее событие увеличивает их 
число до 50. Половина из них продает изделия Іпіеі 
на уровне систем, другая же половина — компоненты. 

Через несколько месяцев мы надеемся сообщить о 
нашем первом дистрибьюторе компонентов в Совет- 
ском Союзе. Мы также намерены открыть этим летом 
свой офис в Москве. Здесь будет находиться наш 
постоянный представитель, в чьи функции будет вхо- 
дить оказание всесторонней поддержки нашим дистри- 
бьюторам и заказчикам. 

Присутствовал 
на пресс-конференции 
и брал интервью И. Липкин 


Дэвид Смолл — человек, первым приступивший к изго- 
товлению эмулятора МасіпіозН на Аіагі ЗТ — представил 
на ганноверской ярмарке СеЬіІ новую серию продуктов для 
улучшения пользовательских характеристик эмулятора 
МасіпІозЬ Зресіге ССК. 

Две крупнейшие новинки — дополнительная плата к 
Меда ЗТ, позволяющая подсоединяться к локальной сети 
АррІеТаІк, и новая версия собственно эмулятора, поддер- 
живающая неамериканские драйверы клавиатуры Мае, а 
также программы Баупа ИОЗ Моипіег и Арріе Рііе 
ЕхсНапда, полностью эмулирующие звуковые эффекты 
(что представляло проблему в прошлой версии) и поддер- 
живающую мониторы с большим разрешением. 

Кроме того, разработана плата МедаТаІк, позволяющая 
использовать на Аіагі любые платы расширения, изготов- 
ленные для МасіпіозН, включая модемы, сетевые карты, 
факс платы и т.д. 

NеюЬу^е$ N 61 * 0 ^, МагсН 75, 1991. 

Фирма ТозНіЬа выпустила портативный компьютер 
Т32005ХС с цветным жидкокристаллическим экраном. 


Этот компьютер, весящий 7.7 кг, сочетает в себе мощность 
процессора 803863Х и активный матричный цветной дис- 
плей размером 10 дюймов. Дисплей воспроизводит 256 
цветов из палитры в 185000 оттенков. Так как дисплеи та- 
кого типа потребляют значительную мощность, этот “на- 
стольный портативный “ компьютер питается от сети. 

Ыешшек, МагсН 18, 1991 . 

Токио. В настоящее время фирма НІіасНі ІЛб. 
разрабатывает цветной плоский дисплей для рабочих 
станций. Матричный дисплей размером 10 дюймов (25.4 
см) появится на рынке через 2 года и будет иметь 
разрешение 1120x780 точек. Дисплей будет в состоянии 
отображать одновременно 512 цветов из палитры 4096 
цветов. 

Время обновления экрана колеблется от 20 до 30 
миллисекунд, а соотношение контрастности превышает 
100:1. Дисплей имеет более 2.6 миллиона пикселов, 
каждый из которых несет в себе цветовую триаду. 

Еіесігопіс Еп&пеепп& Тітез , ЫоѵетЪег 5, 1990. 
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Немного о ОІ5кТе5і 

Неплохая программа проверки состояния диска 
ЭізкТезІ, входящая в пакет ІЧогІоп ШіШіез Асіѵапсесі 
ЕсШіоп, позволяет не только обнаружить сбойные 
кластеры, но и перенести оказавшиеся на них файлы 
в безопасное место. Для этого от пользователя требу- 
ется одна дополнительная операция: на запрос про- 
граммы о том, нужно ли отметить найденные сбойные 
кластеры как дефектные. 

Однако проявление сбоя при чтении, в сущности, 
процесс случайный, поэтому любознательный пользо- 
ватель наверняка заметит, что при разных проходах 
ЭізкТезІ находит различные сектора. Поэтому, чтобы 
повысить вероятность обнаружения опасных для рабо- 
ты мест на диске, лучше выполнить проверку неоднок- 
ратно. В общем, достаточно элементарно написать ко- 
мандный файл, который будет в цикле вызывать про- 
грамму ИТ.ЕХЕ, но все равно после каждого прохода, 
в котором удалось обнаружить сбойные области диска, 
пользователь должен будет подтверждать необходи- 
мость исключения их из дальнейшего использования. 

Для решения этой проблемы следует использовать 
ключ /т при вызове ОізкТезІ. В этом случае нечитае- 
мые сектора без лишних вопросов будут отмечёны как 
дефектные. Используя такую форму вызова ЭізкТезІ, 
можно написать командный файл, который будет про- 
верять диск, пока вы не прервете его работу, нажав 
Сігі-С. Ниже приведен его текст. 

:1аЬе1 

БТ/Л/М 

СОТО ІаЬеІ 

Запустите эту программу, уходя обедать, и это вре- 
мя не пройдет зря. Особенно, если вы давно не фор- 
матировали диск. 


Компьютеры с процессором 803865Х почти не хуже 
настоящих 80386 

Известно, что процессор 803865Х представляет 
собоЯ упрощенный вариант “настоящего 41 процессора 
80386ЛХ. Отличие заключается в использовании 
16-разрядной шины при обращении к памяти. Внут- 
ренняя структура этих двух процессоров практически 
одинакова. 

Поэтому отвечаем на вопрос о том, какой процессор 
выбрать для пакетов, ориентированных на 80386 (все 
чаще возникающий и у советских пользователей). Все 
режимы 803865Х аналогичны режимам 80386ЛХ. Это 
относится и к работе с памятью. Отличие — в мень- 
шем быстродействии компьютера на базе 803865Х (но 
и его цена значительно меньше!). 

Поэтому любое программное обеспечение, написан- 
ное для 80386, будет успешно выполняться и на 
803865Х. В том числе такие пакеты, как \Ѵіпс1о>ѵз 386, 
ОЕ$(}ѵіе>ѵ 386, трансляторы для 80386, и многие дру- 
гие. 

В то же время при выполнении данных пакетов на 
обычной ІВМ АТ-совместимой машине, они не всегда 
работают как ожидается, возможны даже случаи за- 
висания компьютера при попытках пакета использо- 
вать отсутствующие в процессоре 80286 ресурсы. 

Еще один способ 
использования команды ГОШ 

Эта малоизвестная и нечасто используемая команда 
позволяет облегчить задачу резервного копирования 
дисков. Эту команду удобно применять с утилитами 
РазіЬаск Ріиз фирмы РіНН Сепегаііоп Зузіетз или 
РС Васкир фирмы Сепігаі Роіпі ЗоКѵаге, однако его не 
стоит использовать со стандартной командой ВАСКИР 
операционной системы М5-005. 
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Обычно такие пакеты требуют раздельного выпол- 
нения всех операций для каждого диска. Однако с по- 
мощью команды ЮДО их можно выполнить для всех 
дисков сразу. Скажем, если ваш винчестер разбит на 
три раздела, для создания резервной копии всех дис- 
ков можно использовать такой командный файл: 

ЮШ И: С:\0_ИК1УЕ 
ЮГО Е: С:\Е_ОКІѴЕ 

{здесь нужно ввести имя вашей Ьаскир-про- 
граммы с требуемыми параметрами} 

ГОШ В: /В > ШЬ 
ЮШ Е: /О > ШЬ 

Здесь команда ЮДО описывает логические диски 
как отдельные каталоги на другом диске, что позволя- 
ет скопировать диск С:, заодно получив копии других 
дисков. Единственная хитрость заключается в том, что 
на диске С: действительно должны существовать опи- 
санные каталоги, причем они должны быть пустыми. 

После того, как резервные копии будут готовы, две 
последние строки описанной выше программы восста- 
новят исходное состояние системы. 

Для восстановления резервных файлов подготовьте 
второй командный файл, в третьей строке которого 
нужно просто заменить параметры, чтобы обеспечить 
раскрытие копий. 

Можно использовать аналогичную программу для 
глобального поиска файлов на всех дисках или для 
уничтожения, например, всех файлов с расширением 
.ВАК или же для других групповых операций с файла- 
ми. 

Ошибки вычислений в базах данных 

Наш читатель В.Королевский из города Слоним 
Гродненской обл. обнаружил несколько особенностей 
СУБД 6ВА5Е III Ріиз, РохВА5Е+ 2.00 и 2.01, КЕВ115. 
Надеемся, что эта информация заинтересует .вас. 

При использовании функций ДОТ и МОО для обра- 
ботки результатов каких-либо вычислений, бывают си- 
туации, когда эти функции возвращают неверный ре- 
зультат. Это случается при обработке чисел вида 
XXX. 0000. Функция ШТ(п) может вернуть целое чис- 
ло на единицу меньшее ожидаемого, а функция 
МОО(п.І) — единицу. 

Например, в результате вычисления ДОТ(32.80- 
10.80) вы получите не 22, как можно было бы предпо- 
ложить, а 21. Столь же неожиданным для вас будет 
результат применения функции МСЮ к этому же вы- 
ражению — он будет равен 1. Приведенная разность 
не уникальна. Аналогичный эффект вы можете наб- 
людать, обрабатывая, например, следущие выражения: 

133.92-28.92 

416.08-201.08 

Кроме того, отметим, что некорректное поведение 
функций наблюдается на вполне определенных интер- 
валах изменения операндов. Например, для числовых 
выражений: 


32.80- 10.80 

33.80- 10.80 


41.80- 10.80 

42.80- 10.80 

применение функций ДОТ и МОВ некорректно, а 
вот для: 

30.80- 10.80 

31.80- 10.80 

43.80- 10.80 

44.80- 10.80 и т.д. 

вполне обычно. 

Аналогично можно изменять значения второго опе- 
ранда. Для разностей. 

35.80- 3.80 

35.80- 4.80 


35.80-31.80 

ДОТ и МСЮ опять ведут себя безобразно, если же из 

35.80 вычитать 0.80 или 1.80 или 2.80, как и 32.80, 

33.80 и т.д., то все будет нормально. 

Предлагаем вам подумать о причинах появления 
этого эффекта. 

Если вы работаете с базами данных в одной из 
этих систем и пользуетесь этими функциями, то, что- 
бы ваша голова не болела. Королевский рекомендует 
применять их в следующем виде: 

І = ДОТ(КОІДОО<Ы,14)) 

І = М(Ю<КОІДООДО,14),1) 

Тестирование производилось на компьютерах 
ІВМ РС ХТ и АТ с сопроцессором и без него, 
работающих с операционными системами 
Э05 3.30 и 4.0 и все было в порядке! 

Новые ошибки от СошрасіЗоН 

Если вы считаете, что Ыогіоп Сошшапбег — систе- 
ма для начальников и студентов-второкурсников, если 
вы не можете смотреть на изображение в цветах “го- 
лубой на синем“, то у вас нет (в этой стране) другого 
разумного выбора, кроме пакета ХТгее — по данным 
журналов РС ЛѴогІсІ и РС Ма^ахіпе — самого удобного 
и популярного в мире. 

Недавно в пакете ХТгее Рго Соі 6 версии 1.3 к удо- 
вольствию киевских хакеров нашлась первая и на се- 
годня единственная известная ошибка. 

При просмотре содержимого файлов с помощью ко- 
манды Ѵіеѵ в режиме шестнадцатиричного дампа вы 
никогда не увидите байт Е6, на этом месте на экране 
будет написано Е4, при этом в символьном поле спра- 
ва текст отображается правильно. То же самое проис- 
ходит при шестнадцатиричном редактировании файла. 
Более того, если вы в дамповом редакторе наберете 
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МЕЖДУ ПРОЧИМ... 


Е6, на экране все же появится Е4 и, опять-таки, вер- 
ная буква в символьном поле. 

Знатоки ассемблера могут сообразить, а для осталь- 
ных сообщим, что Е4 — команда ІЫ, Е6 — ОІЛГ. 

Поэтому во избежание подобных случаев предла- 
гается метод исправления этой ошибки. Сделать это 
можно тем же ХТгее Рго Соіб (тот самый доктор, ко- 
торый может сам себя исцелить). В файл 
ХТС_ѴІЕ^.ХТР по смещению 6523Н нужно вписать 
байт 36Н. После такой экзекуции программа начинает 
работать лучше фирменной. Для полного счастья сле- 
дует исправить еще и ламповый редактор 


ХТС_НЕХХ.ХТР. Ошибка в нем точно такая же. 
Найти заветное место, я надеюсь, сможет любой, ис- 
правивший первую. 

И.Вязаничев 
В .Королевский 
Ю.Пронякин 
Т. Шухова 

По материалам: 

Д.Катіп “СотЪипе Огіѵез", РС/СотриІіп^, ЫоѵетЬег, 
1990. 


Сомнения, в каком направлении будут развивать- 
ся графические оболочки, овладевают умами поль- 
зователей компьютеров. Это сильно бьет по карма- 
ну фирмы ІВМ: вместо 05/2 все покупают 

>ѴІПСІОШ5. 

Поэтому фирма провела ряд брифингов с пользо- 
вателями, программистами, аналитиками и прессой 
о путях дальнейшего развития своей операционной 
системы. 

Ключевым сообщением фирмы было то, что 32- 


битная версия 05/2 2.0 будет продаваться уже в 
конце этого года. Джеймс Каннавио, вйце-прези- 
дент ІВМ, назвал это будущее изделие “ДОС луч- 
ший чем ДОС, и ДѴіпбоіѵз лучшие чем \Ѵіпсклѵз“ 
(“а ЬеИег 005 ІЬап 005 апб а ЬеИег АѴіпсІоіѵз Оіап 

>ѴІП<І0\Ѵ5.“) 

05/2 в будущем сможет выполнять программы, 
написанные не только специально для нее, но и для 
005 и >Ѵіпбодѵз. 

Ме\ѵ$ЪуІе8 Не \ѵз Иеімюгк, Аргіі 15, 1991. 



МАЛОЕ ПРЕДПРИЯТИЕ 
“ИНФОРМАТИКА” 

Учредитель - Институт проблем 
информатики Академии Наук СССР 
У ОС - многозадачная унифицированная операционная 
система 

■ одновременная работа нескольких прикладных программ 

■ обмен данными между одновременно работающими программами 

■ синхронизация работы нескольких программ 

■ совместимость с МЗ-БОЗ 

■ настройка системы на любой язык 

■ возможность создания новых шрифтов для дисплея и принтера 

■ возможность использования индивидуального алфавита, кодовой таблицы и клавиатуры 
для каждой из одновременно работающих программ 

■ простота освоения и удобство использования 

117900, Москва, ГСП- 1, В-334, ул.Вавилова, д.30/6, ИПИ АН СССР, Малое 
предприятие “Информатика”. 

Телефон: (095)-362-46-54. Факс; (095) -31 0-70-50. Телекс: 411853 ШРО 811 
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“Опятъ этот ІІШХ“, — проворчат 
недовольно любители М8-И05. “Ну, 
наконец-то, ІІМХ“, — скажут 
удовлетворенно приверженцы 
многопользовательских систем. Одно 
несомненно, — предлагаемая 
информация вызовет большой интерес у 
всех, кто неравнодушен к глобальным 
компьютерным проектам. 


ДВАДЦАТЬ ИГРОКОВ 
РЕШАЮТ ПОЙТИ С ТУЗА 


“Что это? Новый Крестовый поход 
против Советского Союза?", — спросил 
Чип Дейла. 

“Вперед, Спасатели!", — изо всех сил 
закричала Гайка. 

В знакомой всем компьютерным торговцам нашей 
страны формуле пользовательского счастья “покупайте 
Эй-Ти (АТ) + И-ДжиЭй (ЕСА) + широкий принтер + 
винт на сорок 44 программные средства не удостоены 
даже упоминания. Ясно, что МЗ-ЭОЗ. А что же даль- 
ше? 

Хотя дрейф в сторону графических пользовательс- 
ких интерфейсов не обошел стороной и родные про- 
сторы, предчувствие надвигающегося путешествия к 
новым операционным системам еще не посетило душу 
простого советского человека. Более того, фирма 
МісгозоН манит его перспективой скорого появления 
на рублевом рынке русифицированной и очень друже- 
любно к нему, покупателю, настроенной версии систе- 
мы МЗ-ЭОЗ 5.0. 

Если же есть охота поиграться в воспоминания о 
будущем — к услугам эстетов и хакеров еще более 
дружелюбная (если у вас хватит денег на железо) опе- 
рационная среда >Ѵіпс1о>ѵ5 3.0. 

И вот уже, услышав про требования к минимальной 
конфигурации для спокойной жизни с “окошками 44 , 
покупатель издает сдавленный вопль и ошарашенно 
спрашивает: “А может, еще что-то найдется, подешев- 
ле малость? 44 До него доходит, что миграция в область 
операционных систем, в визитной карточке которых 


появляется титул “мульти... 44 , дается очень недешево; 
гнаться за модой нелегко, как свидетельствуют о том 
коммерческие магазины. Так . ради чего и в какой мо- 
мент стоит пересчитать имеющуюся наличность и от- 
правляться в плавание к новым берегам? 

Многозадачность для человека, занимающегося ин- 
дивидуальной трудовой деятельностью, — свойство ту- 
манное. Ветераны, разработавшие не одну систему 
р-р-реального времени на “Электронике-60 44 , относят- 
ся к многозадачности а Іа \ѴіпсІодѵ5 со скептицизмом и 
ядреным юмором деда Щукаря. Много всего понаворо- 
чено, а прерывание обработать — так замаесси. 

Те же из ветеранов, шрамы которых своим появле- 
нием обязаны ІЫМОЗ'у или ЭЕМОЗ'у (в девичестве — 
ОС ІІЖХ), не спешат переносить привязанности сво- 
ей боевой молодости на настольную игрушку, будь она 
хоть с 486-м процессором. “Имидж не тот, 44 — хмуро 
бормочут ветераны этого полка. “ѴАХ — там куда ни 
шло, а на этой персоналке от ЫЖХ'а проку никако- 
го 44 . Задиристая молодежь из малых и мельчайших 
предприятий попыталась было прельстить покупателя 
лейблом ІІШХ'а на “Эй-Ти +... (см. выше) 44 , но пока 
безуспешно. Даже смелый бросок в 32-разрядное цар- 
ство наперевес с застойной идеологией систем подго- 
товки данных (ау, система “Клен 44 ) покупателя не 
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ДВАДЦАТЬ ИГРОКОВ РЕШАЮТ ПОЙТИ С ТУЗА 


вдохновляет. “Это уж вы, ребята, перебрали, — гово- 
рят в один голос закаленные асушники, — Мы ведь 
еще СП Д-9000 не продали, будь она неладна../ 4 . 

Так что для советского анемичного рынка стремле- 
ние бежать за паровозом по имени ЦЫІХ еще как-то 
не сформировалось. И тем не менее следить за марш- 
рутом этого американского локомотива по запутанным 
колеям мирового компьютерного рынка приходится, а 
то момент упустишь. Вспомним, что рождался ІЖІХ 
многопользовательской системой, и подивимся тому, 
как прочно укоренился он на рабочих станциях для 
индивидуалов. Вот уже и наш горделивый САПСАН с 
тевтонским характером несет в когтях лозунг “с 
ІЖІХ'ом Ѵ.4 — хоть куда... 44 ; но хозяевам этой птицы 
кажется, что подчинять ЦМХ капризам одного един- 
ственного пользователя расточительно, их рабочая 
станция — мн ого пультовая. Этак и крыша поедет раз- 
бираться. Итак, что есть ОС ІЖІХ — воплощение ду- 
ха коллективизма или ближайшее будущее для вла- 
дельцев персоналок с 486-м? 

Двадцать фирм со всего света, собравшись под зна- 
менем “Передовой компьютерной среды 44 (Абѵапсеё 
Сотриііпв Епѵігоптепі, АСЕ), объявили 9 апреля од- 
новременно в трех компьютерных столицах — Нью- 
Йорке, Брюсселе и Токио — о создании открытой ин- 
струментальной среды для фирм-интеграторов и поль- 
зователей. Заявка не оригинальная, однако удивляет 
состав команды: здесь и тайваньский лидер (ТНе Асег 
Сгоир), и ветераны американского рынка (Сопігоі 
Эаіа, Оі^ііаі Е^иіртеп1, Ргіше Сотриіег), и солидные 
японские вкладчики (ЫЕС, 5опу), и осторожные евро- 
пейские партнеры (Зіешепз ЫіхсіогГ, Сгоире Виіі, 
Оііѵеііі 5уз1етз & Ыеілѵогкз). Однако и эти зубры на 
поле не играют, отсиживаясь до времени на скамейке; 
в нападении — тройка фирм из молодняка: МІР5 
Сотриіег 5узІетз, 5ап1а Сгит. Орегаііопз (5СО) и 
МісгозоГі. Об остальных чуть позже, а сейчас расшиф- 
руем эмблему этого клуба. “Асе“ по-английски значит 
“туз“, тузов в колоде — четыре, как и положено. 

Во-первых, козырной туз — открытость ко всему 
разумному, что накоплено компьютерными гуру из 
мира ЦМХ'а и М5-Э05. Минимальный стандарт 
РОЗІХ (входной билет в мир совместимости с 
ІШІХ'ом) принят участниками этой команды безогово- 
рочно. Участники программы АСЕ поддерживают ско- 
ординированное развитие как ОС ІЖІХ (в ее реализа- 
ции фирмой Запіа Сгиг Орегаііопз), так и системы 
05/2 фирмы МісгозоГі. Пользовательская оболочка 
ЦЫІХ'а в принятом варианте известна покупателям 
ЗСО-ІІЖХ'а под именем Ореп Оезкіор и ориентирова- 
на на рабочие станции, создаваемые для людей, при- 
вычных к программным продуктам МісгозоГі (да, это 
означает, что вы можете запустить прикладную задачу 
для МЗ-ЭОЗ на правах задачи в ІЖІХ'е). А теперь... 
Слушайте нас внимательно, адепты МісгозоГГа: у ва- 
шего новорожденного вундеркинда, системы 05/2, 
возникает раздвоение личности. Мало того, что у этого 
ребеночка сложились довольно странные взаимоотно- 
шения со своим коммерческим близнецом — \ѴіпсІо\ѵз, 


так еще и юниксоидом быть захотелось. И приобрел 
отныне такой повзрослевший вариант системы 05/2 
второе имя Ые^ѵ ТесЬпоІо^у (ЫТ). 05/2 3.0 (ЫТ) не 
имеет дела с 16-разрядными платформами. А вот сре- 
ди 32-разрядных платформ для рабочих станций 90-х 
годов нашел себе этот продукт эпохи еще и крестного 
отца, при родном папе по имени Іпіеі Х86. Крестным 
стал КЛЗС-процессор фирмы МІР5. “Фирма МісгозоГі 
заботится о развитии стандартов для персональных 
компьютеров, — заявил на презентации программы 
АСЕ Билл Гейтс. — Эта программа предлагает поль- 
зователям возможность работы с КІЗС-архитектурой 
фирмы МІР5. Кроме того, мы будем заботиться и о 
функциональных расширениях ОС для владельцев 
Іпіеі-платформ. Те, кто ведет сегодня разработку при- 
кладных программ для \Ѵіпёошз и 05/2, смогут су- 
щественно расширить рынок для своих продуктов. 44 

Теперь пора разобраться со вторым тузом. Извест- 
но, что ЯІ5С-процессоры живут на мировом компью- 
терном рынке трудной, но интересной жизнью. Для 
начала отметим, что у массовых пользователей ЯІ5С- 
компьютеров пока немного (полторы — две сотни ты- 
сяч). Эти платформы в большинстве своем стали ин- 
женерными рабочими станциями, которые не менее 
чем вдвое дороже “хороших 44 персоналок. Появился 
ЯІ5С-процессор и у фирмы Іпіеі (І80860), но пока он 
на самостоятельность в платформах рабочих станций 
претендует редко, оставаясь на ролях сопроцессора. 
Разборка на К.І5С-рынке идет в основном между двумя 
архитектурами — 5РАКС и МІР5. Для рабочих стан- 
ций ОС ІІЫІХ стала наиболее ходовой за последние 
три-пять лет, и такой альянс подкреплен появлением 
группы стандартов (Х.11, 5ѴЮ, ЫР5, АЫ5І С и уже 
упомянутый Р05ІХ). Так что с открытостью — пер- 
вым тузом в инициативе АСЕ — дела обстоят хорошо. 
Мобильность ІПЧІХ а доказана многажды, и все же мо- 
бильность — это не совместимость. Поэтому поста- 
вщики ЯІ5С-платформ с ЦЫІХ'ом предлагают более 
или менее дешевые лицензии на спецификации своей 
аппаратуры. Сложившийся на базе такой лицензии от- 
ряд фирм 5рагс Іпіегпаііопаі обеспечил себя несколь- 
кими поставщиками процессоров 5РАКС, но эти про- 
цессоры не совместимы по контактам своих микрос- 
хем. Среди ведущих фирм на призыв вступить в груп- 
пу 5рагс Іпіегпаііопаі откликнулись пока 4. Во вновь 
созданной команде АСЕ таких солидных партнеров со- 
бралось десятка полтора... Фирма МІР5 предлагает се- 
годня лицензию на спецификацию АЯС (Абѵапсеб 
ЯІ5С Сотриііп^), охватывающую процессорное ядро, 
магистраль, набор малых интерфейсов, формат и 
цветность графического растра, а также расположение 
клавиш (“де-факто 44 стандарт клона ІВМ РС со 101 
клавишей) и форматы файлов. Такой всеобъемлющий 
стандарт на КЛ5С-платформу, да еще с участием 
фирм первой десятки компьютерного мира, имеет се- 
рьезные шансы на успех. 

Третий туз в колоде — сохранение облика ІІЫІХ'а 
как многопользовательской системы. Дебют 
5С0-ІЖІХ под именем Хепіх состоялся с подачи фир- 
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мы МісгозоН на платформах с процессором І80286, для 
которых пользователи хотели иметь возможность рабо- 
ты с небольшим числом А8СІІ-терминалов. В сбыте 
таких платформ преуспела, например, фирма АНоз. 
Развитие ЦЫІХ'а для Іпіеі-платформ фирма 8апІа 
Сгих Орегаііопз прочно захватила в свои руки, и се- 
годня число продаж 8СО-ІЖІХ составляет сотни ты- 
сяч. Участники программы АСЕ приняли решение 
развивать 08/2 как однопользовательскую систему, 
предусмотрев такие направления развития, как под- 
держка многопроцессорных архитектур, многоуровне- 
вой защиты общих ресурсов и встроенной коммуника- 
тивности (способности взаимодействовать с различны- 
ми сетевыми архитектурами). Другим решением за си- 
стемой 8С0-ІЖІХ закреплена область многопользова- 
тельских систем с поддержкой симметричных многоп- 
роцессорных архитектур, коммуникативности (в том 
числе с сетевыми архитектурами ЭЕСЫеІ и 8ЫА) и 
модели “клиент-сервер 44 при работе в интегрирован- 
ных локальных и региональных сетях. В этой реализа- 
ции ІЖІХ'а обязательным становится соблюдение та- 
ких стандартов, как 08Р АЕ5, Х/Ореп ХРСЗ и 5ѴШ 
Іззие 2 (и, разумеется, общего с 08/2 стандарта 
Р08ІХ 1003.1). Участие в команде фирмы ЭЕС делает 
правдоподобным утверждение о координации развития 
систем ЗСО-ЦЖХ и ОьТЕІХ. О реализации графичес- 
кой оболочки в составе 8СО Ореп Эезкіор на равных 
правах с \Ѵіпс1о\ѵз и Ргезепіаііоп Мапа&ег уже упоми- 
налось, так что и здесь следует ожидать быстрого 
сближения. 

Такое перекрестное опыление четырех саженцев в 
компьютерном саду — систем 08/2 и ІШІХ, плат- 
форм МІР8 КІ8С и Іпіеі х86 — должно привлечь раз- 
работчиков прикладных программ и модулей расшире- 
ния для рабочих станций, серверов и классических 
многопользовательских систем с терминалами. Есть 
надежда, что гибридные плоды не заставят себя ждать; 
позиции МісгозоП и 8ап(а Сгиг Орегаііопз на рынке 
программных средств сильны (35000 и более 4000 
программных продуктов в фонде" для каждой линии 
соответственно), а такие фирмы, как ЭЕС, 8і1ісоп 
СгарЫсз, 8іешепз Ыіхбогі, Оііѵеііі и Сгоире Виіі, спо- 
собны внести в фонд прикладных программ свои про- 
дукты с устоявшейся репутацией на отраслевых и ре- 
гиональных рынках. Симптоматично участие в про- 
грамме АСЕ фирм, имеющих широкую известность в 
узких кругах. Например, фирма Тапсіеш Сошриіегз 
лидирует на рынке отказоустойчивых систем для бан- 
ков, транспорта и связи; фирмы Ргіше Сошриіег и 
Сопігоі Эаіа занимают устойчивые позиции на рынке 
САПР; фирма >Ѵап^ ЬаЬогаІогіез лидирует на рынке 
систем для научных исследований. Поэтому четвертым 
тузом в колоде программы АСЕ безусловно является 
присутствие в этой команде фирм, знающих, что та- 
кое “вертикальные сегменты рынка 44 , на отечествен- 
ном новоязе получившие название проблемно-ориен- 
тированных систем. Добавим, что с объявлением про- 
граммы АСЕ существенное подкрепление на компью- 
терном рынке получили магистрали ЕІ8А и 


ТІІКВОСНаппеІ, что для них совсем не лишнее в усло- 
виях конкуренции с магистралью МісгосНаппеІ фирмы 
ІВМ. Ставка, покрываемая этим четвертым тузом — 
50 миллиардов долларов; именно этим числом оцени- 
вается совокупный годовой оборот фирм — участниц 
АСЕ. 

Итак, исходные позиции программы АСЕ: 

- наличие нескольких поставщиков для КІ8С-процес- 
сора МІР8, выпускающих совместимые по контак- 
там СБИС; 

- переход к массовым поставкам как 8СО-ІІЫІХ, так и 
08/2 ЫТ в виде продуктов полиграфического класса 
(под этим неуклюжим определением авторы пони- 
мают жаргонное американское “зНгіпкшгар 
зоЦ\ѵаге“ — “программный продукт в термоусадоч- 
ной пластиковой оболочке 44 — т.е. программы, рас- 
пространяемые в розничной торговой сети); 

- участие ведущих фирм компьютерного мира; 

- опора на фонд прикладных программ для ІІЫІХ и 
>Ѵіпбо^ѵз; 

- работа со всеми каналами сбыта, включая сбыт фир- 
мам — интеграторам прикладных систем, независи- 
мым фирмам — поставщикам программ и аппарату- 
ры, а также массовым пользователям через рознич- 
ную сеть. 

Еще одна цитата из выступления на презентации 
программы АСЕ в апреле 1991 года. “Мы считаем, что 
программа АСЕ даст дорогу лавине технических инно- 
ваций и конкретных выгод для пользователей по при- 
меру эпохи становления индустрии персональных ком- 
пьютеров... Положено начало быстрому распростране- 
нию систем нового поколения в стандарте АСЕ для 
наиболее важных сегментов компьютерного рынка в 
90-х годах. 44 ' Автор этих слов — партнер АСЕ, прези- 
дент фирмы Сошрая Сошриіег Род Кэннон. Он вместе 
с Биллом Гейтсом, Кеннетом, Олсеном (президент 
фирмы ЭЕС), Дагом Майкелсом (президент 8СО) и 
Робертом Миллером (президент МІР8) выступил пору- 
чителем этой амбициозной программы. 

Для любителей технических подробностей стоит со- 
общить некоторые характеристики “рабочей лошадки 44 
программы АСЕ — КІ8С-процессора К4000. Этот про- 
цессор имеет 64-разрядную ширину тракта обработки 
данных и включает в себя центральный процессор, 
процессор целочисленной арифметики, процессор 
арифметики с плавающей точкой, диспетчер памяти и 
кэш-память нижнего уровня; реализация всех перечис- 
ленных составляющих проведена в одном корпусе 
СБИС. Фирма МІР8 не занимается производством 
СБИС, предоставляя лицензию внешним поставщи- 
кам; сегодня в их число входят ЫЕС, 8іетеп5 ЫіхсІогГ, 
Ь8І Ьо^іс Іпіе^гаіесі Эеѵісе ТесНпоІо^у и Регіогтапсе 
8ешісопс1исІог5. 

Важной особенностью архитектуры МІР8 КІ8С-про- 
цессоров, позволяющей радикально повышать произво- 
дительность, является “суперконвейеризация вычисле- 
ний 44 ( 44 5ирегріре1іпіп2“) — схема спаривания команд, 
подаваемых в конвейер команд на каждом такте рабо- 
ты процессора. 64- разрядная магистраль данных мо- 
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жет показаться экзотикой, однако разработчики фир- 
мы МІР5 утверждают, что это техническое решение 
абсолютно неизбежно для архитектур 90-х годов. За- 
дачи компьютерной графики вплотную подошли к 
пределу 32-разрядной адресной сетки. Ширина внут- 
ренней магистрали кэш-памяти в К4000 и вовсе со- 
ставляет 128 разрядов, что необходимо для согласова- 
ния всех схем управления конвейером. 

Для читателей, настроенных на решительные дело- 
вые предложения, сообщаем, что 1 1 апреля в Москве 
подготовлено для прессы следующее совместное заяв- 
ление: 

“Фирма 5СО и совместное предприятие Риіиге 
ТесНпоІо^іез Іпіегпаііопаі (РТІ) объявляют, что они 
достигли договоренности, согласно которой РТІ высту- 
пает в роли ведущего дистрибьютора программных 
продуктов Запіа Сгиг Орегаііопз в СССР. До недавнего 
времени программные продукты 8СО, получившие 
распространение в СССР, поставлялись легально за- 


падными фирмами только в составе систем “под 
ключ 44 . Получили также хождение версии некоторых 
продуктов 8СО из различных “неформальных 44 источ- 
ников. Путем установления контактов, подобных 
объявленому, фирма 5СО рассчитывает придать регу- 
лярный характер каналам сбыта своей продукции 44 . 
Речь идет о поисках дилеров по отраслям и регионам, 
заинтересованных на первых порах в оснащении плат- 
форм класса І386/486 системой 5СО УЖХ/Ореп 
Оезкіор и различными инструментальными програм- 
мными средствами для АСУ, САПР и САНИ. СП РТІ, 
партнером которого является австрийская фирма 
РиШге ТесЬпоІо^іез (торговый дом, специализирую- 
щийся в области высоких технологий), заинтересовано 
также в сотрудничестве по локализации программных 
продуктов $С(Х 

А. Гиглавый , К . Чащин 


ОБЪЯВЛЯЕТСЯ ПОДПИСКА 

Дей А.К. ѴепШга РиЫізйег 2.0: практическое пособие: Пер. с англ. — 
12 л. Пер.изд.: Оау, Р.СоІіп. Шіпд ѴепШга РиЫізЬег 2.0 (изіп^ Ше 
Ргоіеззіопаі ЕхШпзіоп). Охіогсі Шіѵегзііу Ргезз, Англия, 1990.: 10 руб., 
50 000 экз. 

Прекрасно структурированное практическое пособие для пользователей 
одной из самых популярных в своем классе программе верстки для ПК. 
Книга охватывает как базовый комплект пакета ѴепШга РиЫізЬег, так и 
профессиональное расширение. Даются четкие определения базовых поня- 
тий программы. Описываются возможности подготовки полос издания, 
включающих многоколоночное размещение текста, рисунки, формулы и 
таблицы, создание и вывод на печать репродуцируемого оригинал-макета. 

Для редакционно-издательских и научных работников, а также 
практиков, занятых внедрением прогрессивных методов подготовки 
различных типов. 

Для оформления подписки необходимо перевести указанную сумму на 
расчетный счет 606501 Химкинского отделения Промстройбанка СССР, 
МФО 211747, Предприятия «ЮНИТИ», г. Химки, выслать копию пла- 
тежного поручения и заявку с указанием Ваших почтовых реквизитов по 
адресу: 103062, Москва, а/я 86. 
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Японская фирма Куосега объявила о своих намере- 
ниях начать продажи в США и Европе своего миниа- 
тюрного компьютера КеГаІо с рукоп исным вводом тек- 
ста. 

КеЫо — это комбинация компьютера размером А5 
и записной книжки. Весящий всего 650 грамм, он вы- 
полнен на базе процессора 1ЧЕС ѴЗО, имеет прошитую 
в ПЗУ М5-005 3.22, а также последовательный порт 
для связи с другими машинами. 

Информация в компьютере хранится на специаль- 
ных магнитных карточках. В комплекте с компьюте- 
ром продаются записанные на таких носителях тексто- 
вый редактор, дневник, записная книжка, часы и 
изощренный калькулятор. Фирма сейчас разрабатыва- 
ет еще одну карточку, которая позволит осуществлять 
обмен небольшими сообщениями по радио. 

Фирма заявляет, что начинает разработку делового 
программного обеспечения, ориентированного на евро- 
пейский рынок. Готовый продукт вместе с программа- 
ми появится в продаже осенью этого года в Европе и в 
начале следующего года — в США. 

МемзЪуІез 1Ѵе\ѵ$ ІѴеІлѵог к, Лргіі 17, 1991. 

В планы компании Арріе входит образование от- 
дельного подразделения для работы на рынке СССР и 
Восточной Европы. Штаб-квартира Арріе Сепігаі 
Еигоре будет находиться в Варшаве. 

Фирма планирует начать продажу своих компьюте- 
ров на рынках бывши* социалистических стран, как 


только закончит весьма непростой процесс локализа- 
ции программного обеспечения. По мнению многочис- 
ленных представителей фирмы, выходить на рынки 
без готового софтвера — только себе вредить. 

Парижский представитель фирмы сообщил, что 
окончание соответствующих работ в разных странах 
планируется примерно на одно и то же время — лето 
этого года. Сразу за этим последуют объявления о на- 
чале продаж. 

На западе компания сильна в области поставок ма- 
шин школам и университетам. В СССР ей придется 
побороться за этот рынок с ІВМ и рядом других ком- 
паний. 

Кстати, представители Арріе гордо заявляют, что на 
столе у Президента Горбачева стоит МасіпІозЬ. 

По оценке Московского представителя Арріе Грега 
Борровски, сейчас в СССР имеется не более тысячи 
компьютеров МасіпІозН. Тогда как, по утверждению 
Хейки Аувинена, финского консультанта по советской 
электронной промышленности, ІВМ-совместимых ма- 
шин в стране насчитывается от одного до полутора 
миллионов, причем ближе к одному, чем к полутора. 

Ыем ’$ЪуІе$ Ме\ѵ5 Ыеіѵюгк, Аргіі 15, 1991. 

Фирма АзЫоп-ТаІе начала поставку программы 
(ША$Е IV КипТіте Ріиз, которая позволит работать с 
любыми прикладными системами, написанными на 
СІВА5Е IV, версия 1.1, на компьютере МасіпІозЬ. Цена 
пакета 195 долл. 
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Теперь СІВА5Е существует в четырех различных 
средах — под М5-005, на компьютерах Оі^ііаі 
Едиіршепі ѴАХ с ОС ѴМ5; на рабочих станциях 5ип 
Місгозузіетз с версией системы ІІпіх — 5ип05; и на 
компьютерах МасіпІозН. 

Кроме предоставления простого средства выполнять 
программы, КипТіте Ріиз имеет дополнительные воз- 
можности для создаігия, модификации и отладки 
(ША5Е программ на компьютере МасіпІозН. 

ЫехѵзЪуІез Ые\ѵ$ ЫеЫюгк, Аргіі 10, 1991 . 

Цветной термопринтер выпущен канадской фирмой 
СаІСотр. Он печатает на бумаге стандартного форма- 
та АЗ с разрешающей способностью 300 точек на 
дюйм. 

Краска при нагреве переносится со специальной 4- 
цветной (зеленый, желтый, красный, черный) термо- 
чувствительной ленты на бумагу по одному цвету за 
проход печатающей головки. Также поставляются чер- 
ные одноцветные ленты для быстрой однопроходной 
печати. По заявлению фирмы, принтер может воспро- 
изводить “тысячи цветов 44 . 

Полностью совместимый с АсІоЬе РозіЗсгірІ, прин- 
тер может подключаться к компьютеру через интер- 


фейсы АррІеТаІк, К5-232, ЗС5І или параллельный 
порт. В одну из моделей встроен алгоритм преобразо- 
вания векторной графики в растровую, что упрощает 
его использование в системах САПР. 

Ые\ѵ5Ъу\*е8 ІЯем >8 КеЫюгк , Аргіі 11, 1991. 

Девятнадцатилеты ий нью-йоркский хакер Марк 
Абене, известный под кличкой РНіЬег Оріік, был при- 
говорен судом к 35 часам коммунальных работ за до- 
ступ к компьютеру без разрешения. 

Абене был арестован 5 февраля полицией штата 
Нью-Йорк и обвинен во вмешательстве в работу ком- 
пьютера и проникновение в него без разрешения, что 
по законодательству США считается уголовным пре- 
ступлением. Обвинения были сняты, когда обвиняе- 
мый чистосердечно признал себя виновным в “неза- 
конном использован ѵ іи компьютера 44 . Приговор поло- 
жил кіжец году неопределенности в его судьбе — ор- 
дер на изъятие его компьютера был выдан в январе 
1990 года. 

Абене заявил, что отработает требуемое наказание в 
местном госпитале. 

Ые\ѵ8Ьу\'е8 Ые\ѵ8 ЫеЬѵогк, Аргіі 8, 1991. 
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Советско-американское предприятие “Соваминко 
Рекламно-издательское агентство “ КомпьютерПресс 


Принимает заказы на журнал “ КомпьютерПресс “ и 
производит отправку наложенным платежом. 


Заказ высылается по адресу: 191186, Ленинград, Невский проспект, 28, 

Магазин № 1 «Дом книги » 
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МАЛОЕ ПРЕДПРИЯТИЕ 

"ИНФОРМАТИКА” 



Логическое 

программирование 


Инструментальные 

средства 


ПРОГРАММНЫЕ ПРОДУКТЫ 
ЛЕКЦИИ, КОНСУЛЬТАЦИИ. 
СОЗДАНИЕ ПРИКЛАДНЫХ 
ПРОГРАММ 


Текстовые 

процессоры 


Стохастические 

системы 


Операционные 

системы 


УЧРЕДИТЕЛЬ - Институт проблем информатики Академии наук СССР 

У 


Объектно-ориентированное 

программирование 




МЫ УБЕЖДЕНЫ, ЧТО С НАШЕЙ 
ПОМОЩЬЮ ВЫ СМОЖЕТЕ ОПЕРАТИВНО 
ПОЛУЧАТЬ И ПЕРЕДАВАТЬ ЛЮБУЮ 

ИНФОРМАЦИЮ 


- Мы обеспечим Вам оперативный 
компьютерный доступ к БАНКУ 
коммерческой, научной, 
промышленной информации 

и электронной РЕКЛАМЫ. 

- Мы оперативно свяжем Вас 

с поставщиками или покупателями 
через брокерские фирмы различных 
БИРЖ в нашей стране и за рубежом. 


Различные модели модемов для 
ІВМ РС/ХТ/АТ, ЕС1840/41 /42, 
ДВК-2/3/4; встроенные и внешние по 
стыку К5-232/С2; а также модемы, 
совместимые с модемами "СотрГіпк 

С4800". 




- Мы поможем автоматизировать 
работу вашего банка, разработаем 
недорогие системы сбора любой 
информации (метеорологической, 
экологической, с нефте- 
и газопроводов, _ 
водохранилищ 

и так далее] ци. , 

по телефонным 

каналам. ^ ■ / 1 — - — 




